/*
Theme Name: RDSGN ORIGINAL									
*/

/**********************************************
    PC版 CSS
**********************************************/
@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lobster&display=swap');

.pc{
	display:none;
}
:root {
  --grey: #2B2B2E;
  --red: #D31C30;
}

/**************************************************************
全体
**************************************************************/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
    outline: 0;
    font-size: 100%;
    scroll-behavior: smooth;
}
body {
    font: 500 16px/1.75 "Noto Sans JP", sans-serif;
    color: #4e4e4e;
    text-align: left;
    letter-spacing: 0.05em;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    font-size: 13px;

    margin: 0px;
    text-align: center;
    line-height: 180%;
}
/**************************************************************
リンク
**************************************************************/
a:link {
    color: #4e4e4e;
    text-decoration: none;
	transition: 1.0s ;
}
a:visited {
    color: #4e4e4e;
    text-decoration: none;
}
a:hover {
    color: #4e4e4e;
    text-decoration: none;
}
a:active {
    color: #000;
    text-decoration: none;
}
/**************************************************************
アウトライン
**************************************************************/
#outline {
    margin: 0px auto;
    padding: 0px;
    width: 980px;
    background: #FFFFFF;
}
/**************************************************************
ヘッダー
**************************************************************/
#title {
    margin: 0px;
    padding: 0px;
    position: relative;
    text-align: left;
}
#title-inner {
	padding:15px;
    margin: 0 auto;
    display: flex;
    align-items:center;
    justify-content: space-between;
}
#title-inner .logo {
	width:50%;

}
#title-inner .logo img {
    width: 100%;
    height: auto;
    display: block;
}

#title-inner .set{
	width:50%;
    float: right;
    display: flex;
    font-size: 15px;
    text-align: center;
    line-height: 150%;
    align-items: center;
}

#title-inner .set a{
    margin-left: 5px;
}


#title-inner .set .pf{}
#title-inner .set .pf a{
    display: block;
    padding: 10px 20px;
    background-color: #e40b1e;
    color: #fff;
    display: flex;
    align-items: center;
}

#title-inner .set .pf a:hover{
    background-color: #cd0617;
}

#title-inner .set .pf img{
    width: 15px;
    height: auto;
}
#title-inner .tel{
    font-weight: 600;
    font-size: 26px;
    color: #4e4e4e!important;
}





/**************************************************************
Humberger
**************************************************************/
.menu-btn {
        position: fixed;
        top: 3px;
        right: 4px;
        display: flex;
        height: 45px;
        width: 45px;
        justify-content: center;
        align-items: center;
        z-index: 90;
        border-radius: 5px;
        z-index: 120;
}

.menu-btn span,
.menu-btn span::before,
.menu-btn span::after {
    content: '';
    display: block;
    height: 3px;
    width: 25px;
    border-radius: 3px;
    background-color: #969696;
    position: absolute;
    transition: all 0.3s;
}

.menu-btn span::before {
    bottom: 8px;
}

.menu-btn span::after {
    top: 8px;
}

#menu-btn-check {
    display: none;
}

/* アイコンがチェック時に変化する部分 */
#menu-btn-check:checked + label.menu-btn span {
    background-color: transparent;
}

#menu-btn-check:checked + label.menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
}

#menu-btn-check:checked + label.menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
}

/* メニューの表示設定 */
.menu-content {
    width: 60%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 100%;
    z-index: 80;
    background-color: #a60202;
    transition: left 0.5s ease; /* メニュー表示アニメーション */
	z-index:100;
	padding-top:40px;
}

.menu-content li{
	list-style:none;
}

/* チェック時にメニューが表示される */
#menu-btn-check:checked ~ .menu-content {
    left: 40%;
}

.menu-content a {
    padding: 5px 15px;
    display: block;
    border-bottom: dotted 1px #fff;
	color:#fff!important;
	display:flex;
}

.menu-content a img{
	width:20px;
	height:auto;
	margin-right:25px;
}

.menu-content h3 {
    font-size: 18px;
    padding-bottom: 5px;
    margin-top: 15px;
    color: #fff100;
    border-bottom: solid 2px #fff100;
    font-family: 'Rubik', sans-serif;
	margin-bottom:25px;
}


.bb-botan a{
	display:block;
	padding:10px;
	background-color:#ea4c48;
	color:#fff;
	font-size:13px;
	width:80%;
	margin:0 auto;
	margin-top:10px;
	border-bottom:none!important;
	border-radius:3px!important;
}



/**************************************************************
Footer
**************************************************************/
.top-mv{
  background: url(../../../image/top/mv-bg.jpg) center/cover no-repeat;
  position: relative;
  height: 600px;        /* 必須：高さがないと見えません */
  overflow: hidden;
}

/* 背景だけ暗く（または明るく）するオーバーレイ */
.top-mv::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.9) ; /* 黒で暗く。明るくしたいなら rgba(255,255,255,.3) など */
  pointer-events: none;
}

.top-mv2{
  background-image: url("https://home-nico-kaitai.com/wp-content/uploads/2025/10/zemtai-scaled.jpg")!important;
	background-size:140%;
	 height: 600px;
	background-position:bottom;
}
.top-mv2 .top-mv-inner{
    margin: 0 auto;
    box-sizing: border-box;
	padding:20px;
    padding-top: 60px;
}
.top-mv2 .top-mv-inner .hh{
	font-size:14px;
}

.top-mv2 img{
	margin-top:20px!important;
}

/* 上部ライン（右→左） */
.top-mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 100%;   /* 最初は右端の外 */
  width: 100%;
  height: 1px;
  background: red;
  animation: lineRightToLeft 10s linear infinite;
}

/* 下部ライン（左→右） */
.top-mv::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: -100%;  /* 最初は左端の外 */
  width: 100%;
  height: 1px;
  background: red;
  animation: lineLeftToRight 10s linear infinite;
}

/* アニメーション定義 */
@keyframes lineRightToLeft {
  0%   { left: 100%; }
  100% { left: -100%; }
}

@keyframes lineLeftToRight {
  0%   { left: -100%; }
  100% { left: 100%; }
}

.top-mv-inner{
    margin: 0 auto;
    box-sizing: border-box;
	padding:20px;
    padding-top: 160px;
}

.top-mv h2{
    font-size:20px;
    font-weight: 800;
}

.top-mv h3{
    font-size: 20px;
    font-weight: 600;
    margin-top: 20px;
    text-shadow:
        0 0 4px #fff,
        0 0 8px #fff,
        0 0 12px rgba(255,255,255,0.8);
}
.top-mv h3 span{
    font-family: "Barlow", sans-serif;
    font-weight: 700;
    font-size: 25px;
    text-shadow:
        0 0 4px #fff,
        0 0 8px #fff,
        0 0 12px rgba(255,255,255,0.8);
}
.top-mv img{
	width:100%;
    height: auto;
    margin-top: 30px;
}

/**************************************************************
TOP ABOUT
**************************************************************/

.about-sec{
  position:relative;
  padding:80px 0 80px;
  background:#fff;
  color:#1f2937; /* text */
  overflow:hidden;

}
.about-wrap{
  margin:0 auto;
  position:relative;
  padding:0 24px;
}


/* 右上の大きい “About” 背景文字 */
.about-sec::after{
  content:"About";
  position:absolute; right:40px; top:40px; z-index:0;
  font-size:80px; line-height:1; 
  color:#f1cfd5; opacity:.7; transform:rotate(-8deg);
  pointer-events:none;
  font-family: "Lobster", sans-serif;
  font-weight: 400;
  font-style: normal;
}

/* ===== Layout ===== */
.about-grid{

}

/* ===== Text side ===== */
.about-wrap h2{
  font-weight:700; 
    font-size:22px; 
    margin-bottom: 30px;
    z-index: 2;
    position: relative;
}
.about-wrap h2 img{
    height: 30px;
    width: auto;
}





.about-text .lead{
  font-size:16px; 
  line-height:1.7; 
  margin:0 0 14px; 
  font-weight:700;

}
.about-text .desc{
  color:#6b7280; 
  line-height:1.9; 
  margin:0 0 18px;
  text-align: left;
    font-size: 14px;
}

.about-text .desc br{
	display:none;
}

/* 箇条書き（スマイルアイコン付き） */
.about-text .points{ 
    list-style:none; 
    margin:0; 
    padding:0; 
    margin-top: 20px;
}

.about-text .points li{ 
    line-height:1.8;
    padding-bottom: 10px;
    padding-top: 10px;
    border-bottom: dashed 1px #ccc;
    font-size: 16px;
    text-align: left;
    font-weight: 600;
}
.about-text .points img{
    width: 25px;
    height: auto;
    margin-right: 10px;
    vertical-align: bottom;
}
.about-text .points span{
    color: #e40b1e;
}



/* ===== Photo side ===== */
.about-photo{ margin:0; align-self:start; justify-self:end;
margin-top:25px;}
.about-photo img{
  display:block; width:100%; height:auto; border-radius:10px;
  background:#fff; border:6px solid #fff;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}



/**************************************************************
CTA　共通
**************************************************************/
/* CTAセクション */
.cta {
background:
  repeating-linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.08) 0 6px,
    rgba(255, 255, 255, 0) 6px 12px
  ),
  linear-gradient(0deg, var(--red) 0%, var(--red) 100%);
  padding: 30px 0;

}

.cta__inner {
	padding:20px;
  margin: 0 auto;
    position: relative;
    text-align: left;
    box-sizing: border-box;
}
.cta__inner h2{
  font-weight: 600;
  font-style: normal;
    font-size: 24px;
    color: #fff;
    margin-bottom: 15px;
    color: #fae800;
	text-align:center;
}
.cta__inner p{
    font-size: 14px;
    font-weight: 600;
    color: #fff;
}

.cta__inner .woman{
    position: absolute;
    bottom: -30px;
    left: -10px;
}
.cta__inner .woman img{
    width: 130px;
    height: auto;
	display:none;
}

.cta__flex{
    margin-top: 30px;
}


.cta__flex .f-box{
    margin: 1%;
    padding: 15px;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 5px;
	margin-bottom:10px;
}

.cta__flex .f-box .time{
    font-size: 12px;
    font-weight: 500;
    line-height: 130%;
    margin-bottom: 5px;
    text-align: center;

}
.cta__flex .f-box .tel{
    font-size: 33px;
    font-weight: 700;
    line-height: 100%;
    text-align: center;
}

.cta__flex .f-box2{
    margin: 1%;
    padding: 15px;
    box-sizing: border-box;
    background-color: #fff;
    border-radius: 5px;
}

.cta__flex .f-box2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 1%;
  padding: 15px;
  box-sizing: border-box;
  background-color: #fff;
  border-radius: 5px;
  color: #a32320; /* テキスト色 */
	margin-bottom:10px;
}

.f-box2__icon{
    width: 15%;
}

.cta__flex .f-box2__icon img {
  width: 100%;
  height: auto;
}

.cta__flex .f-box2__text {
  flex: 1;
  margin: 0 10px;
}

.cta__flex .f-box2__lead {
  font-size: 13px;
  color: #333;
  margin: 0 0 1px;
    text-align: center;
}

.cta__flex .f-box2__main {
  font-size: 18px;
  font-weight: bold;
  margin: 0;
  line-height: 1.2;
  color: #a32320;
    font-weight: 600;
    text-align: center;
}

.cta__flex .f-box2__arrow{
    width: 10%;

}
.cta__flex .f-box2__arrow img{
    width: 100%;
    height: auto;
}


/*********************************************
TOPメニュー
***********************/

.top-menu {
  padding: 100px 20px;
  background: #f7f7f7; /* 必要なら外してOK（ページ背景に合わせて） */
}
.top-menu__inner {
  max-width: 1100px;
  margin: 0 auto;
}

/* 見出し */
.top-menu__head {
  text-align: center;
  margin-bottom: 28px;
}
.top-menu__head h2 {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: .02em;
}
.top-menu__note {
  margin: 0;
  font-size: 14px;
  color: #777;
  line-height: 1.7;
  padding: 20px 0;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
.top-menu__note br{
	display:none;
}

/* カードグリッド */
.top-menu__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

/* カード */
.top-menu__grid .menu-card {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease;
}
.top-menu__grid .menu-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 34px rgba(0,0,0,.16);
}

/* 画像 */
.top-menu__grid .menu-card__img {
    width: 25%;
    margin: 0 auto;
    margin-top: 15px;
}
.top-menu__grid .menu-card__img img {
  width: 100%;
    height: auto;
}

/* テキスト */
.top-menu__grid .menu-card__body {
  padding: 16px 18px 18px;
}
.top-menu__grid .menu-card__lead {
  margin: 0 0 6px;
  font-size: 12px;
  color: #666;
}
.top-menu__grid .menu-card__title {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 800;
  color: #c9312c;        /* 見本に近い赤 */
  letter-spacing: .04em;
}
.top-menu__grid .menu-card__desc {
  margin: 0;
  font-size: 13px;
  color: #555;
  line-height: 1.7;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	text-align:left;
}
.top-menu__grid .menu-card__desc br{
	display:none;
}

/**************************************************************
TOP料金
**************************************************************/

.top-price {
  background: #faefe9;             /* 薄いピンクの背景 */
	padding:40px 20px;
}
.top-price__inner {
  max-width: 1100px;
  margin: 0 auto;
}

/* heading */
.top-price__head {
  display: flex;
  align-items: baseline;
  gap: 18px;
  margin-bottom: 22px;
}
.top-price__title {
  font-size: 30px;
  line-height: 1;
  font-weight: 600!important;
  color: #2b2b2b;
  margin: 0;
    letter-spacing: -0.5px;
}
.top-price__catch {
  margin: 0;
  font-size: 13px;
    font-weight: 600;
}

/* grid */
.price-grid {
    display: flex;
    justify-content: center;
    margin: 30px 0;
	flex-wrap:wrap;
}

/* card */
.price-card {
	width:48%;
	margin:1%;
	box-sizing:border-box;
  background: #fff;
  border: 1px solid #e9d2cc;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  display: flex;
  flex-direction: column;
}

/* red head with diagonal stripes */
.price-card__head {
  position: relative;
  padding: 10px 14px;
background:
  repeating-linear-gradient(
    135deg,
    rgba(255,255,255,.12) 0 6px,
    rgba(255,255,255,0) 6px 12px
  ),
  var(--red);/* 単色 */
  color: #fff;
  font-weight: 700;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.price-card__head-text { font-size: 15px; }

/* body */
.price-card__body {
  padding: 18px 16px 16px;
  text-align: center;
}

.price-card__icon {
    width: 50px;
    margin: 0 auto;
    margin-bottom: 15px;
}
.price-card__icon img{
    width: 100%;
    height: auto;
}




.price-card__price {
  margin: 8px 0 6px;
  color: #2c2c2c;
  letter-spacing: .02em;
}
.price-card__price strong { font-size: 24px; font-weight: 600; }
.price-card__price span   { font-size: 14px; margin-left: 4px; }
.price-card__price small  { font-size: 11px; color: #777; margin-left: 2px;
display:block;}

.price-card__note {
  margin: 0 0 14px;
  font-size: 12px;
  color: #777;font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

/* button */
.price-card__btn {
    box-sizing: border-box;
  display: inline-block;
  padding: 5px 10px;
  width: 100%;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  box-shadow: 0 6px 0 rgba(0,0,0,.08) inset;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
    color: #fff!important;
}
.price-card__btn:hover {
  opacity: .95;
  transform: translateY(-1px);
}


/**************************************************************
TOP　お困りではありませんか？
**************************************************************/

.problem-hero {
  color: #fff;
  padding: 46px 20px 52px;
  background:
    /* 左上の明るい斜め帯 */
    linear-gradient(
      120deg,
      rgba(255, 255, 255, .10) 0 45%,
      rgba(255, 255, 255, 0) 45%
    ),
    /* 右上のやや暗い斜め帯 */
    linear-gradient(
      -120deg,
      rgba(0, 0, 0, .18) 0 28%,
      rgba(0, 0, 0, 0) 28%
    ),
    #D31C30; /* メインカラー */
}

/* 中身は最大1100pxで中央寄せ */
.problem-hero__inner{
  margin:0 auto;
  align-items:center;
  gap:40px;
}

/* 左の大画像 */
.problem-hero__left{
  flex:0 0 38%;
}
.problem-hero__left img{
  width:100%;
  height:auto;
  display:block;
  border-radius:8px;
  box-shadow:0 12px 28px rgba(0,0,0,.25);
}

/* 右側 */
.problem-hero__right{
  flex:1;
}
.problem-hero__title{
	margin:30px 0 20px 0;
  font-size:20px;
  font-weight:800;
  line-height:1.45;
  letter-spacing:.02em;
}

/* 小カード2枚 */
.problem-hero__cards{
    margin-top: 35px;
}
.mini-card{
  flex:1;
  display:flex;
  align-items:center;
  gap:10px;
  background:#fff;
  color:#2a2a2a;
  text-decoration:none;
  padding:10px 12px;
  border-radius:10px;
  box-shadow:0 10px 22px rgba(0,0,0,.18);
  transition:transform .15s ease, box-shadow .15s ease;
	margin-bottom:15px;
}
.mini-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(0,0,0,.22);
}
.mini-card__img{
    width: 40%;
    margin-right: 2%;
}
.mini-card__img img{
    width: 100%;
    height: auto;
}
.mini-card__body{ min-width:0 }
.mini-card__kicker{
  margin:0;
  font-size:17px;
  font-weight:700;
  color:#a7352d;
  line-height:1.3;
    margin-bottom: 10px;
}
.mini-card__text{
  margin:2px 0 0;
  font-size:11px;
  color:#666;
  line-height:1.1;
    text-align: left;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}


/************************************************************
TOP施工事例
***********************************************************/

.top-works { 
    padding: 40px 20px;
}
.top-works__inner { max-width: 1100px; margin: 0 auto; }
.top-works__title{
  text-align: center;
  font-size: 30px;
  font-weight: 600!important;
  color: #4a4a4a;
  margin: 0 0 26px;
    letter-spacing: -0.5px;
    margin-bottom: 30px;
}

.works-grid{
  margin-bottom: 24px;
}

/* card */
.work-card{
    box-sizing: border-box;
    margin: 2%;
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr .9fr;       /* 画像：情報 */
  padding: 12px;
  border: 2px solid var(--red);             /* 赤枠 */
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(0,0,0,.08);
	
}

/* image */
.work-card__img img{
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  border-radius: 6px;
}

/* info panel */
.work-info{
  position: relative;
  background: #fff;
  border-radius: 5px;
  padding: 5px 10px 10px 10px;
  box-shadow: 0 6px 16px rgba(0,0,0,.06);
}

/* red chip */
.work-chip{
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,.12) 0 6px,
      rgba(255,255,255,0) 6px 12px
    ),
    var(--red);
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  padding: 10px;
  border-radius: 5px;
  white-space: nowrap;
    margin-bottom: 10px;
    line-height: 100%;
}

/* fields */
.work-fields{ list-style: none; margin: 0; padding: 8px 0 0; }
.work-fields li{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 2px solid #eaeaea;
  font-size: 12px;
  color: #333;
}
.work-fields li:last-child{ border-bottom: none; }

/* price line */
.work-fee{ align-items: flex-end; }
.work-price{
  display: inline-flex; align-items: baseline; gap: 2px;
  color: var(--red);
}
.work-price em{
  font-style: normal;
  font-size: 33px;
  font-weight: 800;
  letter-spacing: .02em;
}
.work-price small{ font-size: 12px; color: #8a8a8a; }

/* more button */
.works-more{ text-align: center; margin-top: 8px; }
.works-more__btn{
  display: inline-block;
  background: var(--red);
  color: #fff!important;
  text-decoration: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-weight: 700;
  box-shadow: 0 6px 0 rgba(0,0,0,.08) inset;
  transition: transform .15s ease, opacity .15s ease;
}
.works-more__btn:hover{ opacity: .95; transform: translateY(-1px); }


/***************************************
選ばれる理由
***************/


/* section */
.top-reason { 
  padding: 100px 20px;
  background: #f7f7f7;
    position: relative;
}


/* 右上の大きい “Reason” 背景文字 */
.top-reason::after{
  content:"Reason";
  position:absolute; right:40px; top:40px; z-index:0;
  font-size:70px; line-height:1; 
  color:#f1cfd5; opacity:.7; transform:rotate(-8deg);
  pointer-events:none;
  font-family: "Lobster", sans-serif;
  font-weight: 400;
  font-style: normal;
}




.top-reason__inner { max-width: 1100px; margin: 0 auto; }

/* head */
.top-reason__title{
  margin: 0 0 6px;
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .02em;
  color: #333;
    z-index: 99;
    position: relative;
}
.top-reason__kicker{
  margin: 15px 0 25px;
  text-align: center;
  color: var(--red);
  font-weight: 600!important;
    font-size: 26px;
}
.top-reason__lead{
  margin: 0 auto 26px;
  text-align: center;
  color: #666;
  font-size: 13px;
  line-height: 1.8;
    position: relative;
    z-index: 33;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.top-reason__lead br{
	display:none;
}

/* rows */
.reason-row{
  position: relative;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  margin: 54px 0;
}

/*
.reason-row::before{
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 38%;
  height: 20px;
  background: #ffe8e7;
  border-radius: 8px;
  z-index: 0;
}
*/
.reason-row.reason-row--right::before{
  top: auto; bottom: 36%;
}

/* large number */
.reason-num{
  position: absolute;
  right: 8px; bottom: 8px;
  font-size: 120px;
  font-weight: 800;
  color: #ffe8e7;
  line-height: 1;
  z-index: 0;
  font-family: "Lobster", sans-serif;
  font-weight: 400;
  font-style: normal;
	display:none;
}
.reason-row.reason-row--right .reason-num{ display:none;left: -900px!important; }

/* media + body */
.reason-media{ z-index: 1; }
.reason-media img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
  box-shadow: 0 10px 26px rgba(0,0,0,.12);
}
.reason-body{ z-index: 1; 
padding-top:30px;}

.reason-cap{
  display: inline-block;
  margin: 0 0 12px;
  font-weight: 800;
  color: #222;
  position: relative;
  font-size:22px;
    
}
.reason-cap strong{ color: var(--red);}

.reason-cap::before{
content: "**";
    position: absolute;
    left: -14px;
    right: -14px;
    top: -36px;
    height: 10px;
    color: #ffe8e7;
    font-size: 90px;
    z-index: -1;
    font-family: "Barlow", sans-serif;
    font-weight: 600;
    font-style: italic;
}

.reason-text{
  margin: 0;
  color: #555;
  font-size: 14px;
  line-height: 1.6;
    margin-top: 15px;
    text-align: left;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.reason-text br{
	display:none;
}

/* reverse order for right row */
.reason-row.reason-row--right .reason-media{ order: 2; }
.reason-row.reason-row--right .reason-body{ order: 1; }

/* CTA button */
.top-reason__cta{ text-align: center; margin-top: 18px; }
.reason-btn{
  display: inline-block;
  padding: 12px 26px;
  color: var(--red);!important;
  border: 2px solid var(--red);;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  transition: background .15s ease, color .15s ease, transform .15s ease;
}
.reason-btn::after{
  content: "›";
  margin-left: 10px;
  font-weight: 800;
}
.reason-btn:hover{
  background: var(--red);;
  color: #fff!important;
  transform: translateY(-1px);
}


/**************************************************************
TOP-BLOG
**************************************************************/

.top-blog { 
    padding: 40px 20px; 
    background: #fff; 
    position: relative;
}

.top-blog::after {
    content: "Voice";
    position: absolute;
    left: 40px;
    top: 40px;
    z-index: 0;
    font-size: 70px;
    line-height: 1;
    color: #f1cfd5;
    opacity: .7;
    transform: rotate(-8deg);
    pointer-events: none;
    font-family: "Lobster", sans-serif;
    font-weight: 400;
    font-style: normal;
}


.top-blog__inner { max-width: 1100px; margin: 0 auto; }

/* title with side lines */
.top-blog__title{
  margin: 0 0 18px;
  text-align: center;
  font-size:18px;
  font-weight: 800;
  color: #333;
  letter-spacing: .02em;
	z-index:2;
}
.top-blog__title span{
  position: relative; display: inline-block; padding: 0 18px;
}
.top-blog__title span::before,
.top-blog__title span::after{
  content:""; position:absolute; top:50%; width:30px; height:1px; background:#cfcfcf;
}
.top-blog__title span::before{ right:100%; margin-right:16px; }
.top-blog__title span::after{ left:100%;  margin-left:16px; }

/* grid */
.blog-grid{
	padding:30px;
    z-index: 33;
}

/* card */
.post-card{
    margin: 30px 0;
}
.post-card a{
  display: block;
  color: inherit;
  text-decoration: none;
}
.post-card__thumb{
  position: relative;
  margin: 0 0 10px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
}
.post-card__thumb img{
  width: 100%;
  height: 480px;
  object-fit: cover;
  display: block;
}

/* red badge */
.post-card__badge{
  position: absolute;
  top: 10px; right: 10px;
  background: var(--red);;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px 6px 24px;
  border-radius: 6px;
  box-shadow: 0 4px 10px rgba(0,0,0,.2);
}
.post-card__badge i{
  position:absolute; left:8px; top:50%; transform:translateY(-50%);
  width:0; height:0; border-left:8px solid #fff; border-top:5px solid transparent; border-bottom:5px solid transparent;
}

/* body */
.post-card__body{ padding: 0 4px; }
.post-card__title{
  margin: 0 0 6px;
  font-size: 18px;
  font-weight: 800;
  color: #222;
  line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.post-card__excerpt{
  margin: 0;
  font-size: 13px;
  color: #666;
  line-height: 1.9;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

/* hover */
.post-card a:hover .post-card__title{ text-decoration: underline; }



/**************************************************************
現場ブログ
**************************************************************/

/* ===== top-genba（基本は top-blog と同じスタイル） ===== */

.top-genba { 
    padding: 20px 0 100px 0; 
    background: #fff; 
    position: relative;
}


.top-genba::after {
    content: "Blog";
    position: absolute;
    right: 40px;
    top: -50px;
    z-index: 0;
    font-size: 70px;
    line-height: 1;
    color: #f1cfd5;
    opacity: .7;
    transform: rotate(-8deg);
    pointer-events: none;
    font-family: "Lobster", sans-serif;
    font-weight: 400;
    font-style: normal;
}
.top-event::after {
    content: "Event";
}


.top-genba__inner { max-width: 1100px; margin: 0 auto; }

/* 見出し（左右の飾り線も同じ） */
.top-genba__title{
  margin: 0 0 18px;
  text-align: center;
  font-size: 16px;
  font-weight: 800;
  color: #333;
  letter-spacing: .02em;
}
.top-genba__title span{
  position: relative; display: inline-block; padding: 0 18px;
}
.top-genba__title span::before,
.top-genba__title span::after{
  content:""; position:absolute; top:50%; width:80px; height:1px; background:#cfcfcf;
}
.top-genba__title span::before{ right:100%; margin-right:16px; }
.top-genba__title span::after{  left:100%;  margin-left:16px; }

/* すでにある .blog-grid / .post-card をそのまま利用 */

.top-genba .post-card__thumb img{
  width: 100%;
  height: 200px!important;
  object-fit: cover;
  display: block;
}


/**************************************************************
Staff
**************************************************************/

/* セクション背景は100% */
.top-staff{
  width:100%;
  padding:0px 0 60px;
  background:
    repeating-linear-gradient(-45deg,#eee 0 12px,#ddd 12px 24px);
}

/* 中身は1100px（中央寄せ） */
.top-staff .container{
  width:100%;
  margin:0 auto;
}

/* 見出しバー */
.top-staff .staff-head{
  background:#9a9a9a;
  color:#fff;
  padding:16px 24px;
    margin-bottom: 25px;
		text-align:center;

}

.staff-head-inner{
    margin:0 auto;
  justify-content:space-between;
}


.top-staff .staff-head h2{
  margin:0;
  font-weight:600;
  font-size:22px;
  line-height:1;
    display: none;


}
.top-staff .staff-head .ja{
  margin:0;
  font-weight:700;
  font-size:18px;
  opacity:.95;
}

/* カードレイアウト：flex */
.top-staff .staff-list{
  display:flex;
  flex-wrap:wrap;
	padding:25px 40px;

}

/* 4列固定（1100px内でピッタリ） */
.top-staff .staff-card{
	margin:1%;
	margin-bottom:15px;
  background:#fff;
  border-radius:14px;
  box-shadow:0 10px 20px rgba(0,0,0,.12);
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
}
.top-staff .staff-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 28px rgba(0,0,0,.18);
}

.top-staff .staff-card img{
	width:100%;
	height:auto;
}

/* 画像 */
.top-staff .thumb{
  display:block;
  aspect-ratio:4/3;
  overflow:hidden;
}
.top-staff .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* テキスト */
.top-staff .meta{ padding:12px 16px 16px; background:#fff; }
.top-staff .dept{ margin:0 0 8px; font-size:12px; color:#666; letter-spacing:.05em; font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;}
.top-staff .name{ margin:0 0 4px; font-size:26px; font-weight:800; color:#c62828; letter-spacing:.03em; }
.top-staff .en{ margin:0; font-size:12px; font-weight:700; color:#c62828; letter-spacing:.08em; }


.top-staff .works-more__btn{
    background-color: #565050!important;
}

/**************************************************************
Footer
**************************************************************/

.gototop a{
	z-index:99999999;
  position: fixed;
  bottom: 84px;
  right: 24px;
  width: 48px;
  height: 48px;
  text-decoration: none;
  background-color: var(--red);;
  display: block;
  text-align: center;
  border-radius: 24px;
}

.gototop a::before {
  content: '\f062';
  font-family: 'Font Awesome 6 Free';
  font-size: 30px;
  font-weight: 900;
  color: #fff;
  line-height: 48px;
}

/* 背景100% */
.site-footer{
  background:#2f2f2f;
  color:#e6e6e6;
  padding:48px 20px 64px;
  width:100%;
  font-size:14px;
  line-height:1.9;
    text-align: left;
	box-sizing:border-box;
}

/* コンテンツ幅1100px（中央寄せ） */
.site-footer .container{

  margin:0 auto;
  padding:0 16px;
}


/* 左カラム：会社情報 */
.site-footer .brand{ flex:0 0 33%; min-width:260px; }

.site-footer .logo img{
    width: 250px;
    height: auto;
    margin-bottom: 0px;
}

.site-footer .corp-name{ margin:0 0 6px; font-weight:700; color:#fff; font-size:16px;}
.site-footer address{ font-style:normal; color:#cfcfcf; font-size:13px;}

/* 右カラム：メニュー（3カラム） */
.footer-menus{
	margin-top:25px;
}

.menu-title{
  position:relative;
  margin:0 0 5px;
  padding-left:18px;
  font-weight:700;
  color:#fff;
  font-size:16px;
}
.menu-title::before{
  content:"";
  position:absolute;
  left:0; top:.45em;
  width:0; height:0;
  border-left:8px solid #cc2e2e;          /* 赤い三角 */
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
}

.menu-list{ list-style:none; margin:0; padding:0; 
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 12px;
    padding-left: 15px;
	display:flex;
	flex-wrap:wrap;
	margin-bottom:15px;
}
.menu-list li{ margin:.2em 0; 
width:48%;
margin:1%;
}


.menu-list li.sub a{ font-size:11.5px; 
    opacity:.9;
    padding-left: 11px;
}
.menu-list a{
  color:#e6e6e6;
  text-decoration:none;
  transition:opacity .15s ease;
}
.menu-list a:hover{ opacity:.75; text-decoration:underline; }


/*******固定フッター***********************************/

/* 本文が隠れないよう下に余白を確保（バーの高さ分） */
body { padding-bottom: 65px; } /* 必要に応じて調整 */

/* 固定バー（背景は全幅） */
.sticky-footer{
  position:fixed;
  left:0; right:0; bottom:0;
	box-sizing:border-box;
  background:var(--red);;             /* 赤系 */
  color:#fff;
  z-index:9999;
  box-shadow:0 -4px 12px rgba(0,0,0,.18);
  padding-bottom: env(safe-area-inset-bottom); /* iOSノッチ対策 */
}

/* 内側は1100pxで中央寄せ */
.sticky-footer .sf-inner{
  margin:0 auto;
}


/* 右側（CTA群） */
.sf-ctas{ display:flex;
justify-content:space-evenly;}

.sf-cta{
	width:33%;
	box-sizing:border-box;
  display:flex; 
	align-items:center;
	justify-content:center;
	padding:15px 10px;
  color:#fff!important; 
	text-decoration:none; 
  border-left:1px solid rgba(255,255,255,.35);
  transition: background .15s ease, opacity .15s ease;
    font-size: 13px;
}
.sf-cta:first-child{ border-left:none; }
.sf-cta:hover{ background:rgba(0,0,0,.08); }

/* アイコン */
.sf-icon{ width:20px; height:20px; display:inline-block;
margin-right:5px;}

/*****************************************************************

             　　　    固定ページ共通

*****************************************************************/

.pankuzunavi{
	background-color:#f7f7f7;
	padding:10px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	font-size:10px;
	line-height:130%;
	text-align:right;
}

.sub-header{
	background: url(../../../image/page/base.jpg) no-repeat center / cover;
	padding:40px 10px;
	text-align:center;
	  position: relative;
	overflow:hidden;

}
.sub-header h1{
	font-size:18px;
	color:#fff;
}

/**選ばれる理由**/
.h-reason{
	background: url(../../../image/page/reason.jpg) no-repeat center / cover!important;
}

/**流れ**/
.h-flow{
	background: url(../../../image/page/flow.jpg) no-repeat center / cover!important;
}

/**メニュー**/
.h-menu{
	background: url(../../../image/page/menu.jpg) no-repeat center / cover!important;
}

/**補助金**/
.h-subsidy{
	background: url(../../../image/page/subsidy.jpg) no-repeat center / cover!important;
}

.menu-ttt{
	width:80%;
	margin:0 auto;

}
.menu-ttt img{
	width:100%;
	height:auto;
}

/* 上部ライン（右→左） */
.sub-header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 100%;   /* 最初は右端の外 */
  width: 100%;
  height: 1px;
  background: red;
  animation: lineRightToLeft 10s linear infinite;
}

/* 下部ライン（左→右） */
.sub-header::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: -100%;  /* 最初は左端の外 */
  width: 100%;
  height: 1px;
  background: red;
  animation: lineLeftToRight 10s linear infinite;
}

/***赤矢印***/
.triangle{
  width: 0;
  height: 0;
  border-left: 100px solid transparent;  /* 横サイズの半分 */
  border-right: 100px solid transparent; /* 横サイズの半分 */
  border-top: 50px solid var(--red);;       /* 色＆高さ */
  margin: 10px auto;                    /* 中央寄せ */
}


/*****************************************************************

             　　　    初めての方へ

*****************************************************************/
#beginner{
	margin:0 auto;
	padding:40px 20px;
}

#beginner .trouble{
  margin: 0 auto;
  padding: 20px 0;
  color: #1f2630;
  font-feature-settings: "palt";
}

#beginner .trouble .pill{
  display:inline-block;
  padding: 8px 18px;
  margin: 0 auto 18px;
  border-radius: 999px;
  background:var(--red);;
  color:#fff;
  font-weight:700;
  font-size:14px;
}

#beginner .trouble .ttl{
  margin: 0 0 10px;
  font-size: clamp(24px, 4vw, 38px);
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: .02em;
}

#beginner .trouble .ttl .em{
  display:inline-block;
  background: linear-gradient(90deg, var(--red); 0%, #ff0000 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent;
}

#beginner .trouble .lead{
  margin: 0 0 38px;
  color:#444444;
  line-height:1.9;
  font-size:13px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

#beginner .card{
	margin:1%;
  background:#fff;
  border:1px solid #edf0f5;
  border-radius:16px;
  padding:20px 18px;
	box-sizing:border-box;
  box-shadow: 0 6px 20px rgba(24,32,56,.06);
  display:flex;
  flex-direction: column;
  justify-content: center;
}

#beginner .card .hint{
  position: relative;
  margin: 0 0 10px;
  color:#444444;
  font-size:10px;
  line-height:1.6;
  padding: 0 15px; /* 擬似スラッシュ分の余白 */
  text-indent: 0;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}
#beginner .card .hint::before,
#beginner .card .hint::after{
  content: "＼";
  position:absolute;
  left:0;
  top:0;
  transform: translateY(2px);
  color:#c7cfdd;
}
#beginner .card .hint::after{
  content:"／";
  left:auto;
  right:0;
}

#beginner .card-ttl{
  margin:0;
  font-size: clamp(15px, 2.2vw, 18px);
  line-height:1.55;
  font-weight: 800;
  color:var(--red);; 
}

/* ちょいホバー演出（任意） */
#beginner .card:hover{
  transform: translateY(-2px);
  transition: transform .18s ease, box-shadow .18s ease;
  box-shadow: 0 10px 26px rgba(24,32,56,.10);
}

#beginner .section-demolition{
  margin: 0 auto;
  padding: 40px 20px;
  background: #f7f7f7;
  text-align: center;
  border-radius: 12px;
	margin-top:35px;
	margin-bottom:40px;
}

#beginner .section-demolition .pill{
  display:inline-block;
  padding: 8px 20px;
  background:var(--red);;
  color:#fff;
  border-radius:999px;
  font-weight:700;
  font-size:13px;
  margin-bottom:20px;
}

#beginner .section-demolition .title{
	font-size:18px;
  font-weight:800;
  line-height:1.5;
  margin-bottom:20px;
}
#beginner .section-demolition .title span{
  color:#ff2525;
}

#beginner .section-demolition .lead{
  font-size:13px;
  line-height:1.9;
  color:#333;
  margin:0 auto 40px;
  text-align:left;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
#beginner .section-demolition .lead br{
	display:none;
}

#beginner .section-demolition .points-grid{
  display:grid;
  gap: 20px;
}

#beginner .section-demolition .pic{
	margin:0 auto;
	margin-top:25px;
	margin-bottom:25px;
}


#beginner .section-demolition .pic img{
	width:100%;
	height:auto;
	border-radius:15px;
}

#beginner .section-demolition .point-box{
  background:#fff;
  border-radius:12px;
  padding:20px;
  box-shadow:0 4px 12px rgba(0,0,0,0.06);
  text-align:left;
}
#beginner .section-demolition .point-box img{
  width:100%;
  border-radius:8px;
  margin-bottom:12px;
}
#beginner .section-demolition .point-box h3{
  font-size:18px;
  font-weight:800;
  line-height:1.6;
  margin:0 0 10px;
  color:var(--red);;
}
#beginner .section-demolition .point-box h3 span{
  display:block;
  font-size:14px;
  font-weight:500;
  color:#333;
}
#beginner .section-demolition .point-box p{
  font-size:13px;
  line-height:1.6;
  color:#444;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}
#beginner .merit-section{
  background:#f7f7f7;
  padding:60px 20px;
  text-align:center;
	margin-top:35px;
}

#beginner .merit-section .pill{
  display:inline-block;
  padding:8px 20px;
  background:var(--red);;
  color:#fff;
  border-radius:999px;
  font-weight:700;
  font-size:14px;
  margin-bottom:16px;
}

#beginner .merit-section .subcopy{
  font-size:15px;
  color:#333;
  margin-bottom:12px;
}

#beginner .merit-section .title{
  font-size: clamp(22px, 4vw, 32px);
  font-weight:800;
  line-height:1.5;
  margin-bottom:40px;
  color:var(--red);;
}

#beginner .merit-section .merit-grid{
  display:grid;
  gap:20px;
}


#beginner .merit-section .merit-box{
  background:#fff;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,0.06);
  text-align:left;
}

#beginner .merit-section .merit-box img{
  width:100%;
  display:block;
	height:226px;
}

#beginner .merit-section .merit-box h3{
  font-size:18px;
  line-height:1.6;
  margin:16px 16px 8px;
  font-weight:800;
  color:var(--red);;
}
#beginner .merit-section .merit-box h3 span{
  display:block;
  font-size:14px;
  font-weight:500;
  color:#333;
}

#beginner .merit-section .merit-box p{
  font-size:13px;
  line-height:1.7;
  color:#444;
  padding:0 16px 20px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}


/*****************************************************************

             　　　    選ばれる理由

*****************************************************************/
#reason-page{
  margin:0 auto;
}
	
#reason-page .feature-section{
  text-align:center;
  padding:60px 20px;
  background:#fff;
}

#reason-page .en-title{
	font-size:20px;
  font-weight: 600;
  color: var(--red);;
  margin-bottom: 20px;
  line-height: 100%;
}

#reason-page .sub-en{
  font-size:14px;
  color:#333;
  margin-bottom:24px;
}

#reason-page .jp-title{
  font-size:18px;
  font-weight:700;
  line-height:1.6;
  margin-bottom:40px;
}
#reason-page .jp-title span{
  display:inline-block;
  font-size:22px;
  font-weight:800;
  margin-top:6px;
  color:#000;
}

#reason-page .feature-grid{
	display:flex;
}


#reason-page .feature-box{
	width:24%;
	margin:0.5%;
	background-color:var(--red);;
  color:#fff;
  border-radius:8px;
  padding:10px;
  font-weight:700;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  transition:.25s;
}
#reason-page .feature-box:hover{
  opacity:.9;
  transform: translateY(-3px);
}
#reason-page .feature-box .icon{
  font-size:22px;
  margin-bottom:8px;
  display:block;
}
#reason-page .feature-box .icon img{
  width:35px;
  height:auto;
}
	
#reason-page .feature-box p{
  margin:0;
  font-size:12px;
}
#reason-page .reason-block{
  background:#fff;
  padding:40px 20px;
  margin:0 auto;
}

#reason-page .reason-block .label{
  display:inline-block;
  padding:6px 16px;
  background:var(--red);;
  color:#fff;
  border-radius:4px;
  font-size:14px;
  font-weight:700;
  margin-bottom:16px;
}

#reason-page .reason-block .main-title{
  font-size: 40px;
  font-weight: 800;
  text-align: center;
  color: rgba(171, 32, 25, 0.1);
  margin-bottom: 40px;
  position: relative;
  letter-spacing: 0.05em;
  z-index: 999;
}

#reason-page .reason-flex{
  margin-bottom:40px;
}

#reason-page .reason-img{
}
	
#reason-page .reason-img img{
  width:100%;
  border-radius:8px;
}
#reason-page .reason-text h3{
    font: 500 16px/1.75 "Noto Sans JP", sans-serif;
  font-size:22px;
  font-weight:800;
  line-height:1.6;
  margin-bottom:12px;
  color:var(--red);;
}
#reason-page .reason-text h3 span{
  font-weight:500;
  color:#333;
}
#reason-page .reason-text p{
  font-size:14px;
  line-height:1.8;
  color:#444;
}

#reason-page .reason-grid{
  display:grid;
  gap:20px;
}

#reason-page .reason-box{
  background:#f7f7f7;
  border-radius:8px;
  overflow:hidden;
  padding-bottom:12px;
  text-align:left;
}
#reason-page .reason-box img{
  width:100%;
  display:block;
}
#reason-page .reason-box h4{
  font-size:16px;
  font-weight:700;
  margin:12px 12px 8px;
  line-height:1.5;
  color:#333;
}
#reason-page .reason-box h4 span{
  color:var(--red);;
  font-weight:800;
}
#reason-page .reason-box p{
  font-size:14px;
  line-height:1.7;
  color:#444;
  padding:0 12px;
}

/*******************************
流れ
****************************************/

.rea2-steps-section {
    text-align: center;
	padding:60px 20px;
    background-color: #f9f9f9;
}

.rea2-steps-title {
    font-size: 20px;
    font-weight: bold;
    color: #333;
    margin-bottom: 40px;
}

.rea2-steps {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.rea2-step {
    background-color: var(--red);;
    color: #ffffff;
    padding: 10px;
	box-sizing:border-box;
	margin:1%;
    width: 23%;
    text-align: center;
    border-radius: 4px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start; /* 上に揃える */
}

.rea2-step-number {
    font-size: 16px;
    font-weight: bold;
    margin: 0;
    color: #FFD600;
}

.rea2-step-text {
    font-size: 14px;
    margin: 5px 0;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
}

.rea2-step-arrow {
    font-size: 1.2em;
    margin-top: 5px;
    color: #ffffff;
}


.flow-contact-section {
    background-color: #fff;
    padding: 20px;
    border-radius: 8px;
    max-width: 1000px;
    margin: 0 auto;
      box-shadow: 6px 6px 6px 0px rgba(200, 200, 200, 0.45);
	margin:30px;
}

.flow-contact-image {
    flex: 1;
}

.flow-contact-image img {
    width: 100%;
    max-width: 300px;
    border-radius: 8px;
}

.flow-contact-text {
    flex: 2;
    padding: 0 20px;
}

.flow-contact-title {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
	margin-top:15px;
}

.flow-contact-number {
    background-color: var(--red);;
    color: #ffffff;
    font-weight: bold;
    font-size: 14px;
    padding: 8px;
	line-height:100%;
    border-radius: 5px;
    margin-right: 10px;
    display: inline-block;
    text-align: center;

}

.flow-contact-text h2 {
    color: var(--red);;
    font-size: 18px;
    margin: 0;

}

.flow-contact-text p {
    font-size: 14px;
    color: #333;
    text-align: left;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.flow-contact-link {
    background-color: #007bff;
    color: #ffffff;
    padding: 3px 8px;
    border-radius: 4px;
    text-decoration: none;
    font-weight: bold;
    font-size: 16px;
}
.reason-reason h3 {
    padding: 20px;
	font-size:18px;
    color: #fff;
    line-height: 100%;
    background: repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 6px, rgba(255, 255, 255, 0) 6px 12px), linear-gradient(0deg, #c9312c 0%, #a32320 100%);
    text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
}

	
/**************************************

　解体工事メニュー
	
**********************************************/
	
/* セクション全体 */
.menu-section {
  padding: 40px 20px;
	margin:0 auto;
  background-color: #fff;
  text-align: center;
}

#menu .menu-lead {
  font-size: 14px;
  color: #666;
  margin-bottom: 10px;
}

#menu .menu-title-page {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 60px;
}

#menu .menu-title-page span {
  color: var(--red);; /* 強調カラー */
}

/* グリッド */
#menu .menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 40px;
  align-items: start;
}

/* 各アイテム */
#menu .menu-item {
  text-align: left;
}

#menu .menu-item img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  margin-bottom: 20px;
}

#menu .menu-item h3 {
  font-size: 20px;
  font-weight: 700;
  color: var(--red);;
  margin-bottom: 12px;
}

#menu .menu-item p {
  font-size: 13px;
  line-height: 1.8;
  color: #333;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

	/* ラッパー */
.mm-wrap{
	padding:40px 20px;
  background:#f3f4f6;            /* うすいグレー背景 */

}

/* 見出しブロック */
.mm-head{ margin-bottom:28px; text-align:left; }

.mm-head__chip{
  display: inline-block; 
  background: var(--red);;
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.3;
  padding: 14px 22px;
  border-radius: 999px;
  /* position: absolute; */
  /* margin-left: 300px; */
  /* margin-top: -60px;*/
}
.mm-head__lead{
  color:#333;
  line-height:1.8;
  margin:0;
	padding-top:30px;
	text-align:center;
	font-size:12px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	text-align:left;
}


/* カード */
.mm-card{ background:transparent; 
margin-bottom:20px;}
.mm-card__thumb{
  margin:0 0 14px;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.mm-card__thumb img{
  width:100%; height:auto; display:block;
}
.mm-card__title{
  font-weight:800;
	font-size:20px;
  color:var(--red);;                  /* タイトルも赤系 */
  margin:20px 0 15px;
}
.mm-card__text{
  color:#333;
  line-height:1.9;
  font-size:13px;
  margin:0;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.mm-price {
  padding:40px 20px;
}

.mm-price-img{}

.mm-price-img img{
	width:100%;
	height:auto;
}

.mm-price__inner {
  max-width:900px;
  margin:0 auto;
}

.mm-price__title {
  font-size:30px;
  font-weight:700;
  margin-bottom:10px;
  color:#222;
}
.mm-price__title span {
  display:block;
  font-size:13px;
  font-weight:400;
  color:#da716c;
  margin-top:8px;
}

.mm-price__lead {
  color:#444;
  font-size:13px;
  line-height:1.7;
  margin-bottom:20px;
	text-align:left;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.mm-price__main {
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border-radius:5px;
  box-shadow:0 2px 8px rgba(0,0,0,0.05);
  padding:15px;
  margin-bottom:50px;
}

.mm-price__badge {
  background:var(--red);;
  color:#fff;
  font-weight:700;
  font-size:14px;
  display:flex;
  align-items:center;
  gap:5px;
  padding:10px;
  border-radius:6px;
  margin-right:20px;
	line-height:120%;
}

.mm-price__badge img {
  width:28px;
  height:auto;
}

.mm-price__num strong {
  font-size:36px;
  font-weight:700;
  color:var(--red);;
}
.mm-price__num span {
  font-size:16px;
  color:#333;
  margin-left:8px;
}

.mm-price__list {
  display:flex;
  flex-direction:column;
  gap:40px;
}
	
.mm-price__item{
  margin-bottom:20px;
}

.mm-price__item h3 {
  font-size:18px;
  font-weight:700;
  border-bottom:2px solid #ccc;
  padding-bottom:6px;
  margin-bottom:16px;
  color:#222;
}
.mm-price__item h3 span {
  font-size:12px;
  font-weight:400;
  color:#555;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	line-height:120%;
}

.mm-price__box {
  display:flex;
  align-items:center;
  gap:20px;
}

.mm-price__box span {
  font-size:12px;
  color:#333;
  background:#f9f9f9;
  padding:6px 12px;
  border-radius:4px;
  border:1px solid #ddd;
}

.mm-price__value {
  flex:1;
  font-size:16px;
  font-weight:600;
  padding:10px;
  border:1px solid #ccc;
  border-radius:4px;
  background:#fff;
}
.mm-price__value span{
  background: #fff;
  padding:0;
  border-radius: 4px;
  border: none;
  font-family: "Barlow", sans-serif;
  font-weight: 400;
	font-size:20px;
	font-weight:600;
}




/******************************プチ解体***********************/
	

.petit {
  padding: 30px 20px;
  background: #fff;
}

.petit-grid {
  margin: 0 auto;
	display:flex;
	flex-wrap:wrap;
}

.petit-item {
	width:48%;
	box-sizing:border-box;
	margin:1%;
  border: 1px solid #ddd;
  background: #fff;
  text-align: center;
  box-shadow: 0 3px 8px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.petit-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 12px rgba(0,0,0,0.1);
}

.petit-head {
  background: var(--red);;
  color: #fff;
  font-weight: bold;
  font-size: 15px;
  padding: 10px 0;
}

.petit-item img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

.price {
  font-size: 20px;

  font-weight: bold;
	padding:25px 0;
}

.price span {
  font-size: 14px;

  font-weight: normal;
}
	
.price span .num{
  font-size:16px!important;
}

/* ★ 数字専用フォント指定 */
.num {
  font-family: "Barlow", sans-serif;
  font-weight: 600!important;
  letter-spacing: 0.02em;
	font-size:22px!important;

}

	
	
	
	
	
	
	



	
/* セクション */
.mm-faq { background:#f3f4f6; padding:60px 20px; }
.mm-faq__inner { max-width:900px; margin:0 auto; }

/* 見出し */
.mm-faq__title{
  font-size:40px; line-height:1; font-weight:800; color:#222; margin:0 0 25px;
}
.mm-faq__title span{
  display:block; font-size:13px; font-weight:500; color:#666; margin-top:15px;
  position:relative; padding-left:16px;
}
.mm-faq__title span:before{
  content:""; color:var(--red);; position:absolute; left:0; top:-2px; font-size:22px;
}

/* リスト全体 */
.mm-faq__list{ display:flex; flex-direction:column; gap:14px; }

/* アコーディオン */
.mm-acc{
  border-radius:10px;
	background:#e9edf3; /* 薄いグレー/ブルー → デザイン寄せ */
  overflow:hidden; padding:0;
  border:1px solid rgba(0,0,0,.06);
	text-align:left;
}

/* summary行 */
.mm-acc > summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; gap:14px;
  padding:16px 18px; position:relative; font-weight:700; color:#222;
}
.mm-acc > summary::-webkit-details-marker{ display:none; }

/* 左のQ丸アイコン */
.mm-acc__qmark{
  width:32px; height:32px; border-radius:50%;
  display:inline-grid; place-items:center;
  background:#fff; color:var(--red);; font-weight:800;
  border:1px solid rgba(0,0,0,.08);
  flex:0 0 auto;
  font-family: "Barlow", sans-serif;
  font-weight: 600;
  font-style: normal;
	font-size:20px;
}

/* 質問テキスト */
.mm-acc__q{ flex:1 1 auto;
	font-size:15px;}

/* 右の開閉アイコン（チーvron） */
.mm-acc > summary::after{
  content:""; width:10px; height:10px; border-right:2px solid #666; border-bottom:2px solid #666;
  transform:rotate(45deg); transition:transform .2s ease; flex:0 0 auto;
}
.mm-acc[open] > summary::after{ transform:rotate(-135deg); }

/* 回答 */
.mm-acc__a{
  padding:14px 18px 18px;  color:#333; background:#fff;
  border-top:1px solid rgba(0,0,0,.06);
	font-size:13px!important;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	line-height:160%;
}
.mm-acc__a a{ color:var(--red);; text-decoration:underline; }

/* ホバー時の微アニメ */
.mm-acc > summary:hover{ background:#eef2f7; }



/******************************************
施工事例
******************************************/
.works{
	padding:40px 20px;
}
.works-flex{
    display: flex;
	flex-wrap:wrap;
	align-items:flex-start;
}

.works-flex .ww-box{

    margin: 2%;
    	transition: 1.0s ;
}

.in-flex{
    display: flex;
}

.in-flex .box{
    width: 50%;
    position: relative;
}
.in-flex .box img{
    width: 100%;
    height: auto;
}
.in-flex .box p{
    position: absolute;
    top:0;
    left: 0;
    background-color: var(--red);;
    padding: 5px;
    color: #fff;
    font-size: 13px;
}

.works-flex .ww-box .text{
    background-color: var(--red);;
    color: #fff;
    padding: 15px;
}
.works-flex .ww-box .botan{
    border: solid 1px #fff;
    width: 40%;
    margin: 0 auto;
    margin-top: 5px;
}

.w-ttile{
    font-size:18px;
    text-align: center;}

.works-detail-flex{
    margin-top: 40px;
}


.works-detail-flex .text{

}
.works-detail-flex .box{
    position: relative;
}
.works-detail-flex .box img{
    width: 100%;
    height: auto;
    margin-bottom: 15px;
}
.works-detail-flex .box p{
    position: absolute;
    top: 0;
    left: 0;
    background-color: var(--red);;
    color: #fff;
    padding: 8px 15px;
    font-size: 13px;
}

.works-detail-flex .text .line{
    display: flex;border-bottom: solid 1px #ccc;
}

.works-detail-flex .text .line .mm{
    width: 25%;
    background-color: var(--red);;
    color: #fff;
    padding: 15px 10px;
}
.works-detail-flex .text .line .tt{
    width: 75%;
    background-color: #fff;
    padding: 15px 20px;
    text-align: left;
    font-size: 13px;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.works-detail-flex .text .firstbor{
    border-top: solid 1px #ccc;
}


.apply-botan a{
    display: block;
    padding:15px;
    background-color: #2f2f2f;
    color: #fff;
    font-size: 13px;
    border-radius: 10px;
    margin-top: 20px;
}
.apply-botan a:hover{
    background-color: #e30408;
}


.info-banner2 {
    display: inline-block;
	padding:10px 20px;
    background-color: var(--red);;
    color: #ffffff;
    font-weight: bold;
    font-size: 13px;
    border-radius: 5px;
    position: relative;
    text-align: center;
    margin-top: 50px;
}

.info-banner-arrow2 {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid var(--red);;
}


.info-banner3 {
    display: inline-block;
    padding:10px 20px;
    background-color: var(--red);;
    color: #ffffff;
    font-weight: bold;
    font-size: 13px;
    border-radius: 5px;
    position: relative;
    text-align: center;

}

.info-banner-arrow3 {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid var(--red);;
}

	.info-banner {
    display: inline-block;
    padding:10px 20px;
    background-color: #2f2f2f;
    color: #ffffff;
    font-weight: bold;
    font-size: 13px;
    border-radius: 5px;
    position: relative;
    text-align: center;
}

.info-banner-arrow {
    position: absolute;
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid #2f2f2f;
}

.blog-cate{
    display: flex;
    flex-wrap: wrap;
    margin-top: 25px;
    margin-bottom: 40px;
	justify-content:center;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.blog-cate a{
    padding: 8px;
    display: block;
    background-color: #FFFFFF;
    color: #2f2f2f;
    line-height: 100%;
    font-size: 11px;
	border:solid 1px #2f2f2f;
	width:31%;
    margin: 5px 1%;
    box-sizing: border-box;
}
.blog-cate a:hover{
    background-color: #FFF500;
}
.ww-cate a{
    border: solid 1px #e30408!important;
	color:#e30408!important;
}
	
.w-ttile-taxonomy{
    font-size:16px;
    padding:15px 0;
}
	

/**********************************************
 * お客様の声
**************************************************/
.voice{
	padding:40px 20px;
}
/* voice-tag-list 全体のスタイル */
.voice-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px; /* 各タグ間のスペース */
    list-style-type: none;
    padding: 0;
    margin: 20px 0;
	justify-content:center;
}

/* 各タグリンクのスタイル */
.voice-tag-list li a {
    display: inline-block;
    padding: 10px;
    background-color: #f0f0f0;
    color: #333;
    text-decoration: none;
    border-radius: 5px;
    font-size: 12px;
	line-height:100%;
    transition: all 0.3s ease;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

/* ホバー時のスタイル */
.voice-tag-list li a:hover {
    background-color: #0073e6; /* 好きな色に変更可能 */
    color: #fff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.taglist{

	padding:15px;
}

.tag-ttt{
	font-size:18px;
	font-weight:600!important;
}


.voice-flex{
	padding:30px 20px;

	margin-bottom:30px;
}

.voice-flex .vv{

    margin: 1%;
	border:solid 1px #ccc;
	box-sizing:border-box;
}

.voice-flex .vv img{
    width: 100%;
    height: auto;
}
.voice-flex .vv .text{
    padding: 20px;
    background-color: var(--red);;
    color: #fff;
    font-size: 14px;
}
.voice-flex .vv .text .name{
    color: #FFD31C;
    font-size: 12px;
    margin-top: 10px;
}

.voice-flex .pic img{
    width: 100%;
    height: auto;
}

.voice-flex .tex{
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    box-sizing: border-box;
	margin-top:25px;

}

.voice-flex .tex h3{
    font-size: 18px;
    border-bottom: solid 1px var(--red);;
    color: var(--red);;
    padding-bottom: 5px;
    text-align: left;
    margin-bottom: 15px;
    
}

.voice-flex .tex .textarea{
    text-align: left;
    font-size: 13px;
    line-height: 180%;
    letter-spacing: 0.5px;
}

.bfaf{
    background-color: #2288d6;
    padding: 15px;
    color: #fff;
    font-size: 15px;
    border-radius: 5px;
    margin-top: 50px;
    margin-bottom: 15px;
}

.bfafpic{
    display: flex;
}

.bfafpic .bef{
    width: 35%;
    position: relative;
}
.bfafpic .bef img{
    width: 100%;
    height: auto;
}

.bfafpic .bef p{
    background-color: #9A0002;
    padding: 10px;
    color: #fff;
    position: absolute;
    font-size: 16px;
}

.bfafpic .aff{
    width: 60%;
    position: relative;
    margin-left: 5%;
}
.bfafpic .aff img{
    width: 100%;
    height: auto;
}

.bfafpic .aff p{
    background-color: #259806;
    padding: 10px;
    color: #fff;
    position: absolute;
    font-size: 16px;
}

.arrow{
    text-align: right;
    margin-top: 30px;
}
.arrow img{
    width: 100px!important;
    height: auto;
}




/******************************************
補助金
***********************************************/

.subs{
	padding:40px 20px;
}

.subsidy-section {
    background-color: var(--red);;
    color: #ffffff;
    align-items: center;
    margin: 0 auto;
    border-radius: 8px;
	padding:15px 10px;
}

.subsidy-content h2 {
	font-size:18px;
    font-weight: bold;
    color: #fff;
    margin: 0;
    text-align: center;

}


.subsidy-info {
    display: flex;
    gap: 10px;
    margin-top: 10px;
    justify-content: center;
    font-size: 22px;
}

.subsidy-area {
    background-color: #ffffff;
    color: #d32f2f;
    padding: 10px 15px;
    border-radius: 20px;
    font-weight: bold;
}

.subsidy-latest {
    background-color: #d32f2f;
    color: #ffffff;
    padding: 10px 15px;
    border-radius: 20px;
    font-weight: bold;
}

.subsidy-link {
    background-color: #ffffff;
    color: #333;
    padding: 10px;
    border-radius: 5px;
    font-weight: bold;
	font-size:13px;
}
.sus-text{
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 13px;
    margin-top: 30px;
    margin-bottom: 30px;
    line-height: 180%;
	text-align:left;
}

.hojo-waku{
    padding: 30px;
    background: linear-gradient(to bottom, #f5f5f5, #eaeaea);
    border-radius: 10px;
}

.midashi-botan{
    padding: 15px;
    background-color: #FFFFFF;
}

.subsidy-info-content {
    align-items: center;
    background-color: #ffffff;
    border-radius: 5px;
    overflow: hidden;
    margin-bottom: 15px;
}

.subsidy-info-image {
    width: 280px;
}

.subsidy-info-image img {
    width: 100%;
    height: auto;
    display: block;
}

.subsidy-info-text {
    flex-grow: 1;
    font-size: 16px;
	padding-top:10px;
    color: #333;
    text-align: center;
    font-weight: 600;
}

.subsidy-info-arrow {
    font-size: 15px;
    padding: 0px 0 5px 0;
    color: #333;
    text-align: center;
}

.joho-botan{
    justify-content: center;
    
}

.joho-botan .botan{
    margin-bottom: 15px;
	text-align:left;
    margin: 1%;
}
.joho-botan .botan a{
    display: block;
    padding: 10px;
    background-color: #FFFFFF;
    font-size: 13px;
    border-radius: 3px;
    font-weight: bold;
}
.joho-botan .botan span{
    padding: 5px;
    background-color: #830002;
    color: #fff;
    font-size: 11px;
    border-radius: 3px;
    margin-right: 15px;
    line-height: 100%;
}

.subs-bt{
    margin-bottom: 50px;
}

.hojo-kakushu{
	margin:20px;
    border: solid 5px var(--red);;
    border-radius: 5px;
    background-color: #fff;
    margin-bottom: 30px;
}
.hojo-kakushu .name{
    padding: 15px;
    font-size: 18px;
    font-weight: 600;
    color: #fff;
    background-color: var(--red);;
}

.hojo-kakushu .name span{
    background-color: #fff;
    color: var(--red);;
    padding: 5px 15px;
    line-height: 100%;
    font-size: 16px;
    margin-right: 10px;
    border-radius: 5px;
}

.hojo-kakushu .nakami{
    text-align: left;
    padding: 15px;
}
.hojo-kakushu .nakami .text{
    font-size: 14px;
    line-height: 170%;
	padding:20px 0 20px 20px;
}
.hojo-kakushu .nakami .text h4{
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 20px;
    color: var(--red);;

}

.hojo-kakushu .nakami .pic img{
    width: 100%;
    height: auto;
}
	
/************************************************

	              COMPANY
	
**************************************************/
	
	/* ===== ヒーロー帯 ===== */
#companypage .mm-hero {
  background: linear-gradient(180deg, #fffafa 0%, #f7fafc 60%, #ffffff 100%);
  padding: 40px 20px;
  text-align: center;
}
#companypage .mm-hero__inner{
  max-width: 960px;
  margin: 0 auto;
}
#companypage .mm-hero__title{
  font-size: 20px;
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: .02em;
  margin: 0 0 25px;
}
#companypage .mm-hero__title::after{
  content:"";
  display:block;
  width:300px; height:3px;
  background:var(--red);;               /* アクセントライン（赤） */
  margin:10px auto 0;
  border-radius:2px;
}
#companypage .mm-hero__lead{
  color:#222;
  line-height: 2;
  font-size: 14px;
  margin: 14px 0 0;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	text-align:left;
}

/* ===== メッセージカード ===== */
#companypage .mm-message{

  padding: 0 20px 80px;
}
#companypage .mm-message__card{
  margin: 0 auto;
	padding:20px;
  background:#fff;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
}
#companypage .mm-message__title{
  font-size: 18px;
  font-weight: 800;
  line-height: 1.5;
  margin: 4px 0 18px;
	margin-bottom:20px;
	text-align:left;
}
#companypage .mm-message__body p{
  color:#222;
  line-height: 2;
  font-size: 13px;
  margin: 0 0 14px;
	text-align:left;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

/* 右側：代表写真 */
#companypage .mm-message__figure{
  margin: 0;
  text-align: center;
}
#companypage .mm-message__figure img{
  width: 100%;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 8px 20px rgba(0,0,0,.08);
  display:block;
}
#companypage .mm-message__figure figcaption{
  margin-top: 20px;
  font-size: 13px;
  color:#333;
}
/* ===== company profile (inside #companypage) ===== */
#companypage .mm-company{
  margin: 30px auto 60px;
	padding:20px;
	text-align:left;
}

/* 2カラムの定義リスト */
#companypage .mm-company__table{
  display: grid;
  grid-template-columns: 180px 1fr;     /* 左ラベル / 右本文 */
  column-gap: 2px;
  row-gap: 0;
  border-top: 1px solid #e9c9c3;        /* 最上段ライン */
}

/* 各行の上下ライン */
#companypage .mm-company__table dt,
#companypage .mm-company__table dd{
  padding: 14px 0;
  border-bottom: 1px solid #e9c9c3;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	font-size:12px;

}

/* 左ラベル（赤字・太字） */
#companypage .mm-company__table dt{
  color: var(--red);;
  font-weight: 700;
  line-height: 1.8;

}

/* 右本文：縦の区切り（|）を再現 */
#companypage .mm-company__table dd{
  line-height: 1.9;
  color: #333;
  padding-left: 20px;
  border-left: 1px solid #e9c9c3;
}

/* リンク */
#companypage .mm-company__table dd a{
  color: var(--red);;
  text-decoration: underline;
}
#companypage .mm-company__table dd a:hover{
  opacity: .85;
}

/********************************************************

                      	STAFF

*********************************************************/

.staff-page{
	padding:40px 20px;
}
	
.staff-mes{
  font-size:13px;
  margin:0px 0 20px 0;
	line-height:180%;
}
	
.staff-flex{
  display:flex;
  flex-wrap:wrap;
	margin:35px 0;
}
.staff-flex .st-box{
  width:48%;
  margin:1%;
  box-sizing:border-box;
  border:solid 1px #ccc;
  padding:10px;
}		
.staff-flex .st-box img{
  width:100%;
  height:auto;
}
.staff-flex .st-box .tx{

}	
.staff-flex .st-box .tx h3{
font-size:18px;
}	
.staff-flex .st-box .tx .yaku{
font-size:10px;
color:var(--red);;
}	
.staff-flex .st-box .tx .name{
font-size:12px;
}
/* ===== Layout ===== */
.mm-staff { padding: 30px 20px; }
.mm-staff__grid{}

/* 写真 */
.mm-staff__photo{ margin: 0; }
.mm-staff__photo img{
  width: 100%; height: auto; display: block;
  object-fit: cover;
}

/* カード */
.mm-staff__card{
  position: relative;
  background: #fff; border: 1px solid rgba(171,32,25,.25);
  border-radius: 6px; padding: 26px 28px;
}
.mm-staff__card::before{ /* カード上部の細いライン */
  content: ""; position: absolute; left: 0; right: 0; top: 52px; 
  height: 30px;
  background: rgb(231 231 231 / 35%);

}

/* 見出し部 */
.mm-staff__dept{
  margin: 0 0 6px; font-size: 13px; color: #777; letter-spacing: .08em;
}
.mm-staff__name{
  margin: 0; font-size: 34px; line-height: 1.2; font-weight: 800; color: var(--red);;
	z-index:1;
	position:relative;
}
.mm-staff__nameen{
  margin-top: 6px; font-size: 13px; letter-spacing: .15em; color: #9a3a35;
	z-index:1;
	position:relative;
}

/* プロフィール表 */
.mm-staff__table{
  margin-top: 18px;
  display: grid; grid-template-columns: 90px 1fr; column-gap: 20px; row-gap: 10px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}
.mm-staff__table dt{
  font-weight: 700; color: var(--red);; line-height: 1.8;
	text-align:left;
}
.mm-staff__table dd{
  margin: 0; line-height: 1.9; color: #333;
	text-align:left;
}

	.staff-come{
		text-align:left;
		box-sizing:border-box;
		margin:0 auto;
    background: #f7f7f7;
    position: relative;
    padding: 30px;
    margin: 50px auto;
    display: block;

		font-size:13px;
		font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
		line-height:180%;
	}
	.staff-come h3{
		font-size:28px;
		font-weight:600;
		margin-bottom:30px;
		text-align:center;
	}	
	
	


/***************************************
ショールーム
*******************************************/
	


.show-pic{
    margin-bottom: 30px;
    margin-top: 30px;
}
.show-pic img{
	border-radius:10px;
}


.show-tt h3{
	line-height: 160% !important;
	font-size: 20px !important;
	padding: 20px 0 !important;
}

.show-merit{
	background-color: #ebebeb;
	padding: 10px;
	font-size: 16px;
	font-weight: 600;
	border-radius: 10px;
	margin:20px;
}

.show-box{
    display: flex;
    justify-content: space-between;
	margin:20px;
}
.show-box .pic{
    width: 31%;
	margin:1%;
}
.show-box .pic img{
    width: 100%;
    height: auto;
	border-radius:5px;
}

.shjow-text{
    text-align: left;
    font-size: 13px;
	margin:20px;
    letter-spacing: 0.5px;
    line-height: 180%;
	margin-bottom:40px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}
.show-map{
	margin:30px 20px;
}

.show-map iframe{
    width: 100%;
    height: 300px;
}


/***********************************
お問い合わせ
*********************/

.contact-frame{
    background-color: #fff;
    margin-top: 60px;
    padding: 20px;
    box-sizing: border-box;
    border-radius: 10px;
	margin:0 auto;
}

.contact-frame .c-l{
    padding: 10px 5px;
    border-bottom: dashed 1px #ccc;
    text-align: left;
    font-size: 13px;
    margin-bottom: 10px;
    padding-bottom: 15px;
}

.contact-frame .c-l .tt{
    font-weight: 500;
}
.contact-frame .c-l .mm{
	font-size:13px;
}

.hissu{
    background-color: #CB0003;
    font-size: 10px;
    padding: 3px;
    line-height: 100%;
    color: #fff;
    border-radius: 3px;
    margin-left: 15px;
}



.contact-frame .c-l input[type=checkbox] {
	width:			13px;
	height:			13px;
	-moz-transform:		scale(1.4);
	-webkit-transform:	scale(1.4);
	transform:		scale(1.4);
	margin-bottom:15px;
	margin-right:10px;
}



.wpcf7-text{
  padding: 10px;
  width: 90%;
  color: #636063;
  font-size: 13px;
  background-color:#fff;
  border:solid 1px #CCCCCC;
	margin-bottom:5px;
  }

.wpcf7-text:focus{
  background-color:#fff;
  }

.wpcf7-textarea{
  padding: 10px;
  width: 90%;
  height: 200px;
  color: #636063;
  font-size: 13px;
  background-color:#fff;
  border:solid 1px #CCCCCC;
  }

.wpcf7-textarea:focus{
  background-color:#FFFFCC;
  }

.wpcf7-form-control.wpcf7-submit {
    display: block;
    width: 300px;
    border: none;
    padding: 15px;
    background-color: var(--red);;
    color: #fff;
	font-size:18px;
	border-radius:10px;
	margin-top:50px;

	font-family: Helvetica ,游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-weight: bold;
}

.wpcf7-form-control.wpcf7c-btn-confirm {
    display: block;
    width: 200px;
    border: none;
    padding: 10px;
    background-color: #fff;
    color: #fff;
}

.wpcf7-form-control.wpcf7c-btn-back{
    display: block;
    width: 200px;
    border: none;
    padding: 10px;
    background-color: #fff;
    color: #fff;
    margin-bottom:10px;
}

.wpcf7-form-control.wpcf7-submit:hover{
  filter: alpha(opacity=80);
  opacity: .6;
  -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
  }

span.wpcf7-list-item {
display: block!important;
}

.wpcf7-list-item {
    display: inline-block;
    margin: 0 0 0 0em!important;
}

select{
  padding: 5px;
	margin-top:5px;
  color: #636063;
  font-size: 13px;
  background-color:#fff;
  border:solid 1px #CCCCCC;
}

.kibouday{
	padding:5px;
}

 .clearfix:after{
  content:".";
  display:block;
  height:0;
  clear:both;
  visibility:hidden;
  }

 .clearfix{
  overflow:hidden;
  }

.wpcf7-date{
	padding:5px;  border:solid 1px #CCCCCC;
	margin-right:15px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	font-size:12px;
}

.ap-chui{
	font-size:16px;
	margin-top:20px;
}



/***********************************
お問い合わせ
*********************/

.contact-frame{
    background-color: #fff;
    margin-top: 30px;
}

.contact-frame .c-l{
    padding: 10px 5px;
    border-bottom: dashed 1px #ccc;
    text-align: left;
    font-size: 15px;
    margin-bottom: 10px;
    padding-bottom: 15px;
}

.contact-frame .c-l .tt{
    font-weight: 500;
	font-size:13px;
	margin-bottom:5px;
}
.contact-frame .c-l .mm{

}

.hissu{
    background-color: #CB0003;
    font-size: 10px;
    padding: 3px;
    line-height: 100%;
    color: #fff;
    border-radius: 3px;
    margin-left: 15px;
}

.tel-ap{

}
.tel-ap img{
    width: 400px!important;
    height: auto;
    margin-top: 25px;
}

.apply-flex{
    display: flex;
    justify-content: space-between;
}

.apply-flex img{
    width: 300px;
    height: auto;
}

.apply-ttile{
	font-size:24px;
    font-weight: 600;
	margin-top:20px;
	margin-bottom:50px;
}
	.cc-chui{
		font-size:12px;
	}
	
/* ==== CTA Section ==== */
.mm-cta { padding: 48px 20px 56px; text-align: center; }
.mm-cta__inner { max-width: 960px; margin: 0 auto; }

.mm-cta__title{
	font-size:18px;
	line-height: 1.4; font-weight: 800; margin: 0 0 10px;
}
.mm-cta__lead{
  color:#333; line-height:1.9; font-size:13px; margin:0 0 26px;font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
.mm-cta__lead br{
	display:none;
}

/* Row (call pill + badge) */
.mm-cta__row{
  display:flex; gap:16px; justify-content:center; align-items:center; flex-wrap:wrap;
}

/* Call pill */
.mm-cta__call{
  display:flex; align-items:center; gap:14px; text-decoration:none;
  padding:14px 22px;
  border:2px solid var(--red);; border-radius:999px; background:#fff;
  box-shadow:0 2px 10px rgba(171,32,25,.08);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  color:var(--red);;
}
.mm-cta__call:hover{
  transform: translateY(-1px);
  box-shadow:0 6px 18px rgba(171,32,25,.15);
  background:linear-gradient(0deg, rgba(171,32,25,.05), rgba(171,32,25,.05));
}
.mm-cta__icon{
  display:grid; place-items:center;
  width:40px; height:40px; border-radius:50%;
  background: rgba(171,32,25,.1); color:var(--red);; flex:0 0 auto;
}
.mm-cta__text em{
  display:block; font-style:normal; font-weight:700; font-size:12px; color:#555; letter-spacing:.05em;
}
.mm-cta__text strong{
  display:block; font-size:28px; font-weight:600; letter-spacing:.02em; color:var(--red);;
	margin-top:5px;
}

/* Badge */
.mm-cta__badge{
  display:inline-grid; place-items:center;
  padding:12px 16px; border-radius:16px;
  background: linear-gradient(135deg, var(--red); 0%, #c83d36 100%);
  color:#fff; border:2px solid var(--red);; min-width:150px;
}
.mm-cta__badge-top{
  font-weight:800; font-size:14px; background:#fff; color:var(--red);;
  padding:2px 10px; border-radius:999px; margin-bottom:6px;
}
.mm-cta__badge-bottom{
  line-height:1.3; font-weight:700; font-size:14px;
}

/* Helpers */
.mm-sp{ display:none; }


/************************************
プライバシーポリシー
*******************************************/
.pri-ttt {
	font-size:22px;
    font-weight: 600;
    margin-bottom: 40px;
}

.pri-frame{
	padding:40px 20px;
}
.pri-frame .danraku {
    text-align: left;
    font-size: 13px;
    line-height: 180%;
    letter-spacing: 0.5px;
    padding: 15px 0;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
.pri-frame .danraku li {
    margin-top: 10px;
    margin-left: 25px;
}
.pri-frame h4 {
    background-color: #E8E8E8;
    font-size: 14px;
    border-radius: 5px;
    padding: 10px;
    text-align: left;
    margin: 20px 0;
}
.pri-con {
    margin-top: 40px;
    text-align: left;
    font-size: 13px;
    line-height: 180%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
.pri-con h5 {
    font-size: 15px;
    text-align: left;
    border-bottom: solid 2px #000;
    padding: 5px 0;
    margin-bottom: 15px;
	    font: 500 16px/1.75 "Noto Sans JP", sans-serif;
}
	
	

/*******************************************
協力業者募集
***************/

.part-header{
    margin-bottom: 25px;
	margin-top:30px;
}
	
.part-header img{
    border-radius:10px;
}

.prt-midashi{
    font-size: 18px;
    font-weight: 600;
    text-align: left;
    margin-bottom: 25px;
}

.partner{
	padding:40px 20px;
}

.partner img{
	max-width:100%;
	height:auto;
}

.partner .text-text{
    text-align: left;
    font-size: 14px;
    letter-spacing: 0.5px;
	line-height:200%;
    margin-bottom: 80px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.part-promise{
	align-items:center;
    margin-top: 40px;
}
.part-promise .pic{
	margin-top:35px;
}

.part-promise .pic img{
    width: 100%;
    height: auto;
}

.part-promise .text{
    text-align: left;
    font-size: 14px;
    letter-spacing: 0.5px;
    line-height: 180%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.part-tokuchou{
    font-size: 18px;
    font-weight: 600;
    margin-top: 30px;

}

.part-tokuchou-flex{

}
.part-tokuchou-flex .box{
    margin: 1%;
	margin-top:20px;
	margin-bottom:20px;
}
.part-tokuchou-flex .box img{
    width: 80px;
    height: auto;
}
.part-tokuchou-flex .box h4{
    font-size: 18px;
    color: var(--red);;
    margin-bottom: 15px;
}
.part-tokuchou-flex .box p{
    font-size: 13px;
    text-align: left;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.part-youkou{
    background-color: #417F1F;
    padding: 10px;
    color: #fff;
    font-size: 18px;
    margin-top: 40px;
    border-radius: 5px;
}

.partner-area{
    display: flex;
    border: solid 1px #3A741E;
    font-size: 18px;
    letter-spacing: 0.5px;
    margin-bottom: 25px;
	margin-top:30px;
}
.partner-area .midashi{
    width: 25%;
    background-color: #3A741E;
    color: #fff;
	padding:30px 0;
}
.partner-area .ttt{
    width: 70%;
    margin-left: 5%;
    padding: 10px;
    text-align: left;
	padding:30px 15px;
}

.partner-area .ttt img{
    width: 500px;
    height: auto;
}

.motomeru-partner{
    margin: 0 auto;
    padding: 40px 0;
}

.motomeru-partner h2{
    font-size: 20px;
    color: #BC0003;
    margin-bottom: 20px;
}
.motomeru-partner h3{
    font-size: 16px;
    margin-bottom: 25px;
}
.motomeru-partner p{
    font-size: 14px;
    text-align: left;
    letter-spacing: 1px;
    line-height: 180%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.part-point{
    background-color: var(--red);;
    padding: 10px;
    font-size: 15px;
    border-radius: 5px;
    color: #fff;
}

.point-flex{
    justify-content: space-between;
}

.point-flex .box{
    margin: 10px 0;
    background-color: #fff;
    border: solid 2px var(--red);;
    padding: 20px;
    box-sizing: border-box;
    border-radius: 5px; 
}

.point-flex .box2{
    width: 100%!important;
}

.point-flex .box h3{
    font-size: 16px;
    color: var(--red);;
    margin-bottom: 30px;
}
	
	.point-flex .box .bunsho{
		font-size:13px;
		font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
	}

.point-flex .box2 .b-flex .pic{
    width: 10%!important;
    margin-left: 10%;
}

.point-flex .box2 .b-flex .text{
    width: 80%!important;
}

.b-flex{
    display: flex;
}

.b-flex .text{
    width: 60%;
    text-align: left;
    font-size: 14px;
}
.b-flex .pic{
    width: 38%;
    margin-left: 2%;
}

.b-flex .pic img{
    width: 100%;
    height: auto;
}

	

.blog-list{
    display: flex;
	flex-wrap:wrap;
}

.blog-list .box{
    width: 48%;
    margin: 1%;
    box-sizing: border-box;
    background-color: #f0f0f0;
    text-align: left;
	border:solid 1px #ccc;
}
.blog-list .box img{
    width: 100%;
    height: auto;
}
.blog-list .box h3{

    font-size: 15px;
    margin: 10px 0 5px 0;
}
.blog-list .box .info{
    padding: 15px;
}
.blog-list .box .info .cate{
    background-color: #FFF500;
    padding: 3px;
    font-size: 10px;
    line-height: 100%;
}
.blog-list .box .info p{
    font-size: 12px;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}
.blog-list .box .info .day{
    text-align: right;
    color: var(--red);;
}
/***************************************
ブログ single
******************************************/

#blog{
	padding:40px 20px;
	margin:0 auto;
}



.main-blog .day{
	font-size:30px;
	color:#ccc;
	text-align:right;
	line-height:100%;
	font-weight:600;
}




.blog-midashi {
	font-size:16px;
	font-weight: bold;
	/* color: #ffffff; */
	background-color: #f7f7f7;
	padding: 10px 15px;
	border-left: 5px solid var(--red);;
	border-radius: 5px;
	margin-top: 30px;
	margin-bottom: 40px;
	box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
	text-align: left;
}

.blog-midashi::before {
    content: ''; /* シンボルマークを追加 */
    color: #ffffff;
    margin-right: 8px;
}

.sub-blog{
	padding:30px 0;
}

.sub-blog-midashi {
    font-size: 16px;
    font-weight: bold;
    color: #333;
    padding: 5px 0;
    border-bottom: 2px solid #000; /* 下に黒の2pxの下線 */
    text-align: left;
    margin-bottom: 20px;
    letter-spacing: 0.5px;
    position: relative;
}

.sub-blog-midashi::after {
    content: 'RECENTE BLOG';
	font-size:10px;
    font-weight: normal;
    color: var(--red);; /* アクセントの緑色 */
    margin-left: 10px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.recent-posts {
}

.recent-post-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    background-color: #fff3f3; /* 薄い緑の背景色 */
    border: 1px solid #ffdddd;
    border-radius: 8px;
    text-decoration: none;
	margin-bottom:5px;
}

.recent-post-item img {
    width: 30%;
    height: auto;
    border-radius: 5px;
    object-fit: cover;
}

.recent-post-info {
    display: flex;
    flex-direction: column;
	text-align:left;
}

.recent-post-title {
    font-size: 15px;
    font-weight: bold;
    color: #333;
    margin: 0;
}

.recent-post-date {
    font-size: 0.9em;
    color: var(--red);;
    margin-top: 5px;
    font-family: "Barlow", sans-serif;
}

/*******************************ブログの投稿部分***/

.blog-cont{
        text-align:left;
        margin-bottom:100px;
	font-size:13px!important;
        line-height:200%;
	letter-spacing:0.5px;
	font-weight:400!important;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;

}

.blog-cont li + li {
  border-left: none!important;
}

.blog-cont li{
        margin-left:35px;
        line-height:170%;
        margin-bottom:13px;
}

.blog-cont ol{
        margin-top:25px;
        margin-bottom:25px;
}


.blog-cont p{
        margin-left:15px;
}

.blog-cont .alignright{
        padding-left:15px!important;
        background-color:#fff!important;
        float:right;
}

.blog-cont .alignleft{
        padding-right:15px!important;
        background-color:#fff!important;
        float:left;
}

.blog-cont .aligncenter{
    display: block;
    margin: 0 auto 20px;
    text-align: center;
}

.blog-cont h1{
        font-size:30px;
        color:#000000;
        padding:10px 5px;
        margin-bottom:15px;
        margin-top:30px;
        font-weight: 700;
	font-family:"Noto Sans JP", sans-serif;
}

.blog-cont h2{
        font-size:18px;
        color:var(--red);;
        padding:10px 5px;
        border-bottom:solid 2px var(--red);;
        margin-bottom:15px;
        margin-top:30px;
        font-weight: 600;
	font-family:"Noto Sans JP", sans-serif;
}

.blog-cont h3{
        font-size:16px;
        background-color:#fff3b1;
        padding:7px;
        margin-top:30px;
        margin-bottom:15px;
        font-weight: 600;
	font-family:"Noto Sans JP", sans-serif;
}
.blog-cont h4{
        font-size:15px;
        color:#000;
        padding:7px 3px;
        border-bottom:solid 1px #000;
        margin-bottom:15px;
        margin-top:30px;
        font-weight: 600;
	font-family:"Noto Sans JP", sans-serif;
}

.blog-cont h5{
        font-size:12px;
        color:#000;
        padding:5px;
        background-color:#ececec;
        margin-bottom:15px;
        margin-top:30px;
        font-weight: 600;
	font-family:"Noto Sans JP", sans-serif;
}

.blog-cont p{margin-bottom:15px;}

.blog-cont img{padding-bottom:15px;
padding-top:10px;
max-width:100%;
height:auto;}

.blog-cont iframe{max-width:100%;}

.blog-cont hr{
        margin-bottom:15px;
                margin-top:15px;
        background-color: #fff;
        border-top: 2px dashed #f6be46;
}
/******ページネーション********************/

.pagination {
    display: flex;
    justify-content: center;
    gap: 5px;
    margin-top: 20px;
}

.pagination a, .pagination span {
    padding: 8px 12px;
    border: 1px solid #ddd;
    color: #333;
    text-decoration: none;
    font-size: 1em;
}

.pagination .current {
    background-color: #00a75a;
    color: #fff;
    border-color: #00a75a;
}

.pagination a:hover {
    background-color: #f0f0f0;
}

/******************フッター関連会社******************/
	
.kanren{
	background-color:#f1f1f1;
	padding:20px 10px;
}

.kanren-inner{
	background-color:#fff;
	padding:20px 8px;
	box-sizing:border-box;
	margin:0 auto;
	border-radius:10px;
}
.kanren-inner ul{
	display:flex;
	/*margin-top:25px;*/
	flex-wrap:wrap;
}
.kanren-inner ul li{
	list-style:none;
	width:48%;
	margin:1%;
	font-size:12px;
	border-bottom:dotted 1px #ccc;
	padding-bottom:5px;
	position: relative;
	padding-left: 22px; /* ← アイコン分の余白を確保 */
	box-sizing:border-box;
	text-align:left;

}
/* liの前にアイコンを表示 */
.kanren-inner ul li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 3px;
	width: 12px;
	height: 12px;
	background: url("../../../image/base/icon-ya.svg") no-repeat center center;
	background-size: contain;
}
	
.kanren-inner ul li a:hover{
	color:#cd0505;
}
	
/******************************フッターフォーム********/
	
.f-ap{
	background-color:var(--red);;
	padding:40px 20px;	
}
.f-ap .top-genba__title span{
	color:#fff!important;
}
	
	
.f-ap-inner{
	margin:0 auto;
	background-color:#fff;
	border-radius:10px;
	margin-top:30px;
}	
	
/********************************************************

                      	STAFF

*********************************************************/
	
.staff-mes{
  font-size:14px;
  margin:0px 0 20px 0;
	line-height:180%;
}
	
	.staff-mes img{
		width:100%;
		height:auto;
		margin:20px 0;
		border-radius:10px;
		border:solid 1px #ccc;
	}
	
.staff-flex{
  display:flex;
  flex-wrap:wrap;
	margin:35px 0;
}
.staff-flex .st-box{
  width:48%;
  margin:1%;
  box-sizing:border-box;
  border:solid 1px #ccc;
  padding:10px;
}		
.staff-flex .st-box img{
  width:100%;
  height:auto;
}
.staff-flex .st-box .tx{

}	
.staff-flex .st-box .tx h3{
font-size:18px;
}	
.staff-flex .st-box .tx .yaku{
font-size:11px;
	font-weight:600;
color:var(--red);;
}	
.staff-flex .st-box .tx .name{
font-size: 12px;
color: #ccc;
margin-top: 4px;
	font-weight:600;
}
	
/* ===== Layout ===== */
.mm-staff { padding: 30px 20px; }
.mm-staff__grid{
   margin: 0 auto;

}

/* 写真 */
.mm-staff__photo{ margin: 0; 
margin-bottom:20px;}
.mm-staff__photo img{
  width: 100%; height: auto; display: block;
  object-fit: cover;
}

/* カード */
.mm-staff__card{
  position: relative;
  background: #fff; border: 1px solid rgba(171,32,25,.25);
  border-radius: 6px; padding: 26px 28px;
}
.mm-staff__card::before{ /* カード上部の細いライン */
  content: ""; position: absolute; left: 0; right: 0; top: 52px; 
  height: 30px;
  background: rgb(231 231 231 / 35%);

}

/* 見出し部 */
.mm-staff__dept{
  margin: 0 0 6px; font-size: 13px; color: #777; letter-spacing: .08em;
}
.mm-staff__name{
  margin: 0; font-size: 34px; line-height: 1.2; font-weight: 800; color: var(--red);;
	z-index:1;
	position:relative;
}
.mm-staff__nameen{
  margin-top: 6px; font-size: 13px; letter-spacing: .15em; color: #9a3a35;
	z-index:1;
	position:relative;
}

/* プロフィール表 */
.mm-staff__table{
  margin-top: 18px;

}
.mm-staff__table dt{
  font-weight: 700; color: var(--red);; line-height: 1.8;
	text-align:left;
}
.mm-staff__table dd{
  margin: 0; line-height: 1.9; color: #333;
	text-align:left;
}

	.staff-come{

		text-align:left;
		box-sizing:border-box;
		margin:0 auto;
    background: #f7f7f7;
    position: relative;
    padding: 40px 55px;
    margin: 50px auto;
    display: block;

		font-size:13px;
		font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
		line-height:180%:
	}
	.staff-come h3{
		font-size:28px;
		font-weight:600;
		margin-bottom:30px;
		text-align:center;
	}	
	
	

