@charset "utf-8";
/*
Theme Name:mrp-child
Template:mrp
Version: 1.0.0
*/
/*
DesignCode CSS: ver 0.01
*/
/*------------------------------------------------------
Theme Material
------------------------------------------------------*/

@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho&display=swap");
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1:wght@100..900&family=Poppins: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');


:root {
  /*------â–¼åŸºæœ¬è¨¬å®šâ–¼------*/
  --color-background: #fff;
  --color-background02: #FF7429;
--bg-FFDF29: #FFDF29;
--bg-FFFAD0: #FFFAD0;
--clr-3DAEFF: #3DAEFF;
  --color-background03: linear-gradient(90deg, #00BFFF 0%, #3DAEFF 100%);

  --clr-000: #000;
  --color-font: #333;
  --color-font01: #242424;
  --color-primary: #FF7429;
  --color-table-border: #CACACA;
  --body-font-size: min(calc(1.6rem + (1vw - 19.2px) * 0.1294), 1.6rem); /* 1.6-1.4rem (1920-375) */
  --body-font-family: "Noto Sans JP", sans-serif;
  --content-max-width: 1100px;
  /*------â–¼ãƒ˜ãƒƒãƒ€ãƒ¼è¨¬å®šâ–¼------*/
  --header-background: #FFFFFF;
  --header-color-font: #444444;
  --header-color-primary: #FF7429;
  /*------â–¼ãƒ•ãƒƒã‚¿ãƒ¼è¨¬å®šâ–¼------*/
  --footer-background: #FFFAD0;
  --footer-color-font: #333333;
  --footer-color-primary: #333333;

  /*------â–¼ãƒ•ã‚©ãƒ³ãƒˆè¨¬å®šâ–¼------*/
  --font-family01: "Noto Sans JP", sans-serif;
  --font-family02: "M PLUS 1", "Noto Sans JP", sans-serif;
  --font-family03: "Poppins", "Noto Sans JP", sans-serif;
  
  /*------â–¼pxãƒãƒªã‚¨ãƒ¼ã‚·ãƒ§ãƒ³â–¼------*/
  --px300: min(calc(300px + (1vw - 19.2px) * 10.356), 300px); /*300px-80px (1920-375)*/
  --px240: min(calc(240px + (1vw - 19.2px) * 10.356), 240px); /*240px-80px (1920-375)*/
  --px200: min(calc(200px + (1vw - 19.2px) * 6.4725), 200px); /*200px-100px (1920-375)*/
  --px180: min(calc(180px + (1vw - 19.2px) * 3.8835), 180px); /*180-120px (1920-375) */
  --px170: min(calc(170px + (1vw - 19.2px) * 6.4725), 170px); /*160px-60px (1920-375)*/
  --px160w: min(calc(160px + (1vw - 19.2px) * 5.178), 160px); /*160px-80px (1920-375)*/
  --px160: min(calc(160px + (1vw - 19.2px) * 6.4725), 160px); /*160px-60px (1920-375)*/
  --px150: min(calc(150px + (1vw - 19.2px) * 3.2362), 150px); /*150-100px (1920-375) */
  --px140: min(calc(140px + (1vw - 19.2px) * 6.4725), 140px); /*140px-40px (1920-375)*/
  --px130: min(calc(130px + (1vw - 19.2px) * 2.589), 130px); /*130px-90px (1920-375)*/
  --px120: min(calc(120px + (1vw - 19.2px) * 2.589), 120px); /*120px-80px (1920-375)*/
  --px120s: clamp(50px, calc(50px + ((1vw - 3.75px) * 4.5307)), 120px); /*120px-50px (1920-375)*/
  --px100w: min(calc(100px + (1vw - 19.2px) * 3.2362), 100px); /*100px-50px (1920-375)*/
  --px100: min(calc(100px + (1vw - 19.2px) * 3.8835), 100px); /*100px-40px (1920-375)*/
  --px96: min(calc(96px + (1vw - 19.2px) * 3.1068), 96px); /*96px-48px (1920-375)*/
  --px90: min(calc(90px + (1vw - 19.2px) * 3.8835), 90px);
  /*90px-30px (1920-375)*/
  --px80w: min(calc(80px + (1vw - 19.2px) * 1.2945), 80px); /*80px-60px (1920-375)*/
  --px80: min(calc(80px + (1vw - 19.2px) * 2.589), 80px); /*80px-40px (1920-375)x*/
  --px70: min(calc(70px + (1vw - 19.2px) * 1.9417), 70px); /*60px-30px (1920-375)*/
  --px80s: min(calc(80px + (1vw - 19.2px) * 3.8835), 80px); /*80px-20px (1920-375)x*/
  --px60w: min(calc(60px + (1vw - 19.2px) * 1.2945), 60px); /*60px-40px (1920-375)*/
  --px60: min(calc(60px + (1vw - 19.2px) * 1.9417), 60px); /*60px-30px (1920-375)*/
  --px50: min(calc(50px + (1vw - 19.2px) * 1.2945), 50px); /*50px-30px (1920-375) */
  --px40w: min(calc(40px + (1vw - 19.2px) * 0.6472), 40px); /*40px-30px (1920-375)*/
  --px40: min(calc(40px + (1vw - 19.2px) * 1.2945), 40px); /*40px-20px (1920-375)*/
  --px35: min(calc(35px + (1vw - 19.2px) * 1.2945), 35px); /*35px-15px (1920-375)*/
  --px30w: min(calc(30px + (1vw - 19.2px) * 0.6472), 30px); /*30px-20px (1920-375)*/
  --px30: min(calc(30px + (1vw - 19.2px) * 0.9709), 30px); /*30px-15px (1920-375)*/
  --px24: min(calc(24px + (1vw - 19.2px) * 0.6472), 24px); /*24px-14px (1920-375)*/
  --px20: min(calc(20px + (1vw - 19.2px) * 0.6472), 20px); /*20px-10px (1920-375)*/
  --px18: min(calc(18px + (1vw - 19.2px) * 0.2589), 18px); /*18px-14px (1920-375)*/
  --px16: min(calc(16px + (1vw - 19.2px) * 0.1294), 16px); /*16px-14px (1920-375)*/
  --px14: min(calc(14px + (1vw - 19.2px) * 0.1294), 14px); /*14px-12px (1920-375)*/
  --px12: min(calc(12px + (1vw - 19.2px) * 0.0647), 12px); /*12px-11px (1920-375)*/
  /*------â–¼remãƒãƒªã‚¨ãƒ¼ã‚·ãƒ§ãƒ³â–¼------*/
  --rem120: min(calc(12rem + (1vw - 1.92rem) * 3.8835), 12rem); /*12rem-6rem (1920-375)*/
  --rem80w: min(calc(8rem + (1vw - 1.92rem) * 1.2945), 8rem); /*8rem-6rem (1920-375)*/
  --rem80: min(calc(8rem + (1vw - 1.92rem) * 2.589), 8rem); /*8rem-4rem (1920-375)x*/
  --rem72: min(calc(7.2rem + (1vw - 1.92rem) * 1.9417), 7.2rem); /*7.2rem-4.2rem (1920-375)*/
  --rem70: min(calc(7rem + (1vw - 1.92rem) * 1.9417), 7rem); /*7rem-4.2rem (1920-375)*/
  --rem60: min(calc(6rem + (1vw - 1.92rem) * 1.5534), 6rem); /*6rem-3.6rem (1920-375)*/
  --rem60s: clamp(30px, calc(6rem + ((1vw - 19.2px) * 1.9417)), 60px);
  --rem56: min(calc(5.6rem + (1vw - 1.92rem) * 1.5534), 5.6rem); /*5.6rem-3.2rem (1920-375)*/
  --rem48w: min(calc(4.8rem + (1vw - 1.92rem) * 0.6472), 4.8rem); /*4.8rem-3.8rem*/
  --rem48: min(calc(4.8rem + (1vw - 1.92rem) * 1.5534), 4.8rem); /*4.8rem-2.4rem (1920-375)*/
  --rem42w: min(calc(4.2rem + (1vw - 1.92rem) * 0.6472), 4.2rem); /*4.2rem-3.2rem (1920-375)*/
  --rem42: min(calc(4.2rem + (1vw - 1.92rem) * 1.165), 4.2rem); /*4.2rem-2.4rem (1920-375)*/
  --rem42s: min(calc(4.2rem + (1vw - 1.92rem) * 1.4887), 4.2rem); /*4.2rem-1.9rem (1920-375)*/
  --rem40w: min(calc(4rem + (1vw - 1.92rem) * 0.6472), 4rem); /*4rem-3rem (1920-375)*/
  --rem40: min(calc(4rem + (1vw - 1.92rem) * 1.2945), 4rem); /*4rem-2rem (1920-375)*/
  --rem36: min(calc(3.6rem + (1vw - 1.92rem) * 0.7767), 3.6rem); /*3.6rem-2.4rem (1920-375)*/
  --rem30w: min(calc(3rem + (1vw - 1.92rem) * 0.3883), 3rem); /*3rem-2.4rem (1920-375)*/
  --rem30: min(calc(3rem + (1vw - 1.92rem) * 0.6472), 3rem); /*3rem-2rem (1920-375)*/
  --rem30s: min(calc(3rem + (1vw - 1.92rem) * 0.9709), 3rem); /*3rem-1.5rem (1920-375)*/
  --rem28: min(calc(2.8rem + (1vw - 1.92rem) * 0.6472), 2.8rem); /*2.8rem-1.8rem (1920-375)*/
  --rem26w: min(calc(2.6rem + (1vw - 1.92rem) * 0.3883), 2.6rem); /*2.6rem-1.8rem (1920-375)*/
  --rem24w: min(calc(2.4rem + (1vw - 1.92rem) * 0.3883), 2.4rem); /*2.4rem-1.8rem (1920-375)*/
  --rem24: min(calc(2.4rem + (1vw - 1.92rem) * 0.6472), 2.4rem); /*2.4rem-1.4rem (1920-375)*/
  --rem24s:clamp(14px, calc(2.4rem + ((1vw - 19.2px) * 0.7813)), 24px);
  --rem22w: min(calc(2.2rem + (1vw - 1.92rem) * 0.2589), 2.2rem); /*2.2rem-1.6rem (1920-375)*/
  --rem20w: min(calc(2rem + (1vw - 1.92rem) * 0.2589), 2rem); /*2rem-1.6rem (1920-375)*/
  --rem20: min(calc(2rem + (1vw - 1.92rem) * 0.3883), 2rem); /*2rem-1.4rem (1920-375)*/
  --rem18: min(calc(1.8rem + (1vw - 1.92rem) * 0.2589), 1.8rem); /*1.8rem-1.4rem (1920-375)*/
  --rem16: min(calc(1.6rem + (1vw - 1.92rem) * 0.1294), 1.6rem); /*1.6rem-1.4rem (1920-375)*/
  --rem14: min(calc(1.4rem + (1vw - 1.92rem) * 0.1294), 1.4rem); /*1.4rem-1.2rem (1920-375)*/
  --rem12: min(calc(1.2rem + (1vw - 1.92rem) * 0.0647), 1.2rem); /*1.2rem-1.1rem (1920-375)*/
}

html {
  scroll-behavior: smooth;
}
/* header navbar */
@media print, screen and (min-width: 1024px) {
  nav#mainNav ul li.pc_none {
    display: none;
  }
}
/* header navbar */
@media print, screen and (min-width: 1024px) {
  .sticky-header #header > .inner {
    height: auto;
    background: var(--header-background);
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.2);
  }

  #header a.head_btn.tel_btn {
    color: var(--header-color-primary);
    background: transparent;
    border-left: 1px solid var(--header-color-font);
  }

  #header a.head_btn.tel_btn::before {
    color: var(--header-color-primary);
  }

  #header {
    height: 130px;
  }

  #header a.head_btn {
    align-items: center;
    height: 74px;
    gap: 2px;
    font-weight: bold;
    font-family: var(--font-family02);
    font-size: var(--rem14);
    line-height: 1.4;
    padding: min(calc(10px + (1vw - 19.2px) * 0.2232), 10px) var(--px24);
  }
  #header a.head_btn.shop_btn {
    background: var(--header-bg-02);
    color: var(--header-color-primary);
  }
  #header a.head_btn.shop_btn::before {
    content: "\f07a";
    font-size: var(--rem24);
  }

  #header a.head_btn.mail_btn span {
    font-size: var(--rem16);
    font-weight: bold;
    font-family: var(--font-family02);
  }

  #header a.head_btn.tel_btn::before {
    font-size: 1.25em;
    font-weight: bold;
    margin-bottom: 0;
  }

  #header a.head_btn.mail_btn::before {
    font-size: 1.4em;
    color: var(--header-background);
    margin-right: 8px;
    margin-bottom: 0;
  }

  #header a.head_btn:hover {
    background: var(--header-color-primary);
    color: var(--header-background);
  }
  #header a.head_btn.tel_btn:hover *{
    
    color: var(--header-background) !important;
  }
  #header a.head_btn.mail_btn:hover {
    background: var(--color-background);
    color: var(--header-color-primary);
  }
  #header a.head_btn.mail_btn:hover::before {
    color: var(--header-color-primary);
  }
  nav#mainNav ul li a {
    gap: 8px;
    font-family: var(--font-family02);
  }

  nav#mainNav ul li a b {
    font-weight: bold;
  }

  nav#mainNav ul li a span {
    font-weight: 400;
    color: var(--header-color-primary);
  }

  nav#mainNav ul li.pc_none {
    display: none;
  }
  nav#mainNav ul li.current-menu-item a span,
  nav#mainNav ul li a:hover span,
  nav#mainNav ul li a:active span,
  nav#mainNav ul li.current-menu-parent a span {
    color: var(--header-color-primary);
  }
  #header .logo {
    display: flex;
    align-items: center;
  }

  #header .logo img {
    min-width: 70px;
    height: auto;
    width: 100%;
    margin-right: 8px;
  }

  #header .logo .logo-txt {
    font-size: var(--rem18);
    color: var(--color-primary);
    letter-spacing: 0;
    font-weight: bold;
    line-height: 1.4;
    margin-left: .5em;
    min-width: max-content;
    font-family: var(--font-family04);
    margin-top: .3em;
  }
  #header .logo .logo-txt .jp-logo {
    font-size: var(--rem16);
  }
}

@media print, screen and (min-width: 1024px) {
  #header a.head_btn.tel_btn::before {
    display: none;
  }

  #header a.head_btn.tel_btn span.tel_icon {
    display: flex;
    align-items: center;

    font-size: var(--rem20);
    gap: 8px;
    font-family: var(--font-family-en);
    font-weight: bold;
    color: var(--header-color-font);

  }

  #header a.head_btn.tel_btn span.tel_icon::before {
    font-family: "FontAwesome";
    content: "\f095";
    font-size: 0.75em;
    margin-top: 4px;
  }

  #header a.head_btn.tel_btn span.tel_text-sub {
    font-size: var(--rem12);
    font-weight: bold;
    letter-spacing: .04em;
    color: var(--header-color-font);
  }
  #header a.head_btn.tel_btn span.tel_text-sub b {
    font-weight: inherit;
  }
  #header a.head_btn.mail_btn {
    max-width: 171px;
    min-width: var(--px200);
    height: 74px;
    border-radius: 0;
    padding-left: var(--px20);
    padding-right: var(--px20);
background: var(--header-color-primary);
    gap: 5px;
/* border-left: 1px solid var(--header-color-font); */
border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--header-background);
    font-weight: 500;
    font-size: var(--rem18);
  }
  #header ul.header__contact li{
    display: flex;
    align-items: center;
    padding: 0 var(--px20);
  }
  #header .logo {
    padding-left: var(--px20);
  }
  #header .logo img {
    max-width: 300px;
    max-height: 85px;
    mix-blend-mode: multiply;
  }
  nav#mainNav ul li a:active, nav#mainNav ul li a:hover, nav#mainNav ul li.current-menu-ancestor a, nav#mainNav ul li.current-menu-item a, nav#mainNav ul li.current-menu-parent a {
    background: transparent;
  }
  nav#mainNav ul > li {
    display: flex;
    align-items: center;
    
  }
	nav#mainNav ul li a {
    padding-left: clamp(10px, calc(15px + ((1vw - 19.2px) * 0.558)), 15px) !important;
}
  nav#mainNav ul > li::before {
	  --px83: clamp(31px, calc(83px + ((1vw - 19.2px) * 5.8036)), 83px);
	  --px4: clamp(2px, calc(4px + ((1vw - 19.2px) * 0.2232)), 4px);
    content: "";
    object-fit: contain;
    display: inline-block;
    aspect-ratio: 83 / 84;
    width: var(--px83);
    height: auto;
    background: url(/wp-content/uploads/header-ico-1.png) no-repeat center / contain;
    filter: drop-shadow(0px var(--px4) var(--px4) rgba(0, 0, 0, 0.5));
    transition: .3s all ease-in-out;
  }
  nav#mainNav ul > li.header02::before{
    background: url(/wp-content/uploads/header-ico-2.png) no-repeat center / contain;
  }
  nav#mainNav ul > li.header03::before{
    background: url(/wp-content/uploads/header-ico-3.png) no-repeat center / contain;
  }
  nav#mainNav ul > li.header04::before{
    background: url(/wp-content/uploads/header-ico-4.png) no-repeat center / contain;
  }
  nav#mainNav ul > li.header05::before{
    background: url(/wp-content/uploads/header-ico-5.png) no-repeat center / contain;
  }
  nav#mainNav ul > li:hover::before {
margin-bottom: 8px;
  }
  .sticky-header #header-layout {
    
    height: 100px;
}
}
/* サブメニュー（ulの中のul）だけ ::before を消す */
nav#mainNav ul ul > li::before {
  content: none !important;
  display: none !important;
}
@media print, screen and (min-width: 769px) {
  html:not(.mobile) #mainImg,
  html:not(.mobile) #breadcrumnb {
    position: relative;
    z-index: 11;
  }
}
@media print, screen and (max-width: 1730px) and (min-width: 1024px) {
  #header .logo img {
    width: 100%;
    height: auto;
  }
}
@media print, screen and (max-width: 1400px) and (min-width: 1024px) {
  #header a.head_btn,
  #header a.head_btn.mail_btn {
    padding-left: 10px;
    padding-right: 10px;
  }
  nav#mainNav ul li a {
    padding-left: 11px;
    padding-right: 11px;
    font-size: 11px;
  }
	#header ul.header__contact li {
		padding: 0 var(--px12);
	}
}



/* newslistスタイル 基本パターン */
.postlist {
    .post_text {
        padding: 26px 0;
    }
    li {
        border-bottom: 1px solid #ccc;
    }
}

/* footer */

#footer .footer__logo img {
 
  max-height: calc(var(--px120s) + 5px);
  max-width: 340px;
}
#footer {
  color: var(--footer-color-font);
  font-size: var(--rem14);
  padding: var(--px70) 0 var(--px60);
  background: var(--footer-background);
}
#footer .inner {
  margin-top: var(--px30);
}
#footer .footnav ul > li {
  font-weight: 500;
  padding: 0 var(--px18);
}
/**------------------------------------------
Anchor Point
*------------------------------------------*/

.anchor_link::before {
    content: "";
    display: block;
    padding-top: 150px;
    margin-top: -150px;
  }
.content-inner {
    width: 90%;
    max-width: 1240px;
    margin: 0 auto;
    position: relative;
  }

/* CTA */
body.home #contact-bottom {
    display: none;
  }
  /*-----------------------------
cta01_col2
------------------------------*/
.cta01 {
  background: transparent;
  position: relative;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: stretch;

}

.cta-img01 {
  width: 20%;
  margin: 0 auto;
  max-width: 340px;
  min-width: 100px;
  overflow: hidden;
  position: relative;
}

.cta-img01 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  position: absolute;
}



.cta01 .cta01_wrap {
  max-width: 1240px;
  min-width: max-content;
  width: 90%;
  margin: 0 auto;
  background: #FFDF29;
  padding: clamp(30px, calc(105px + ((1vw - 19.2px) * 4.8544)), 105px) 0 clamp(50px, calc(160px + ((1vw - 19.2px) * 7.1197)), 160px);
  position: relative;

  z-index: 10;
}

.cta01 .cta01_wrap .main-ttl {
	text-align: center;
}

.cta01 .cta01_wrap::before {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 472 / 263;
  width: 38%;
  max-width: 472px;
  height: auto;
  background: url(/wp-content/uploads/cta-img.png) no-repeat center / contain;
  top: var(--px40);
  left: var(--px30);
}
.cta01 .cta01_wrap > p {
  font-size: calc(var(--rem28) - 1px);
  font-weight: 500;
  letter-spacing: .1em;
}
.cta01 .ctabtnlist {
  justify-content: center;
  max-width: 1100px;
  margin: var(--px50) auto 0 auto;
  /*flex-wrap: wrap;*/
  gap: 5px;
}

.cta01 .ctabtnlist li {
  width: calc(calc(100% - 10px) / 2);
  margin: 0;
  padding: 0;
  line-height: 1;
  display: flex;
  min-width: fit-content;
  max-width: 500px;
}

.cta01 a.item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--px30) var(--px12);
  text-align: center;
  box-sizing: border-box;
  color: var(--color-background);
  border-radius: 50vh;
  transition: all ease .15s;
}

.cta01 a.item:hover {
  opacity: 0.8;
}
@media print,
	screen and (min-width: 1921px) {
		.cta01 .cta01_wrap {
			max-width: none;
			width: 60%;
		}
		.cta-img01 {
			width:20%;
			max-width: none;
		}
}
@media print,
screen and (max-width: 1023px) {
  .cta01 .cta01_wrap {
      min-width: auto;
  }
  .cta-img01 {
    width: 30%;
  }
  .cta01 .ctabtnlist li,
  .cta01 .ctabtnlist a.item {
      width: 100%;
	  max-width: none;
  }

  .cta01 .ctabtnlist li+li {
      margin-top: 1rem;
  }
}

@media print,
screen and (max-width: 768px) {

  
  .cta-img01 {
    min-width: auto;
    
  }
  .cta01 .cta01_wrap::before {
    top: 8px;
    left: 8px;
  }
}
@media print,
screen and (max-width: 640px) {
  .cta-img01 {
    width: 5%;

  }
}
/*ボタン共通パーツ*/
	
.cta01 .btnttl {
	display: block;
	font-weight: bold;
	margin-bottom: 1rem;
}
.cta01 .infotxt {
	font-size: var(--rem16);	
	font-weight: bold;
  letter-spacing: .1em;
}
	
/*電話ボタン*/
	
.cta01 .telnum {
	font-size: var(--rem36);
	margin-bottom: 1rem;
  font-weight: bold;
}
.cta01 .telbtn .btnttl {
	font-size: var(--rem20);
}
.cta01 a.telbtn {
    background: var(--color-primary);
	color: var(--color-background);
  
}
	
/*メールボタン*/
	
.cta01 .mailbtn .btnttl {
	font-size: var(--rem24);
}
.cta01 a.mailbtn {
    background: var(--color-background03);
	color: var(--color-background);
}


/*ボタンアイコン*/
	
.cta01 .mailbtn .btnttl::before, .cta01 .telnum::before {
	content: '';
	display: inline-block;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	margin-right: 1rem;
}
.cta01 .mailbtn .btnttl::before {
	content: '\f0e0';
}
.cta01 .telnum::before {
	content: '\f3cd';
}
  
  /*-------------------------------------------
     MV切り替え
  --------------------------------------------*/
  /* @media screen and (min-width: 751px) {
    .sp_mv {
      display: none;
    }
  }
  @media screen and (max-width: 750px) {
    .pc_mv {
      display: none;
    }
  } */
  
  .main-ttl, .post .main-ttl {
font-weight: bold;
font-size: var(--rem26w);
letter-spacing: .1em;
font-family: var(--font-family02);
color: var(--color-font);
margin: 0;
margin-bottom: 1em;
  }

  .main-ttl > .en-ttl {
    display: block;
    color: var(--color-font);
    font-weight: 800;
    letter-spacing: .06em;
    font-size: var(--rem70);
    line-height: 1.2;
    text-transform: uppercase;
  }

  .main-ttl.long-ttl > .en-ttl {
    font-size: clamp(40px, calc(8rem + ((1vw - 19.2px) * 2.589)), 80px);
  }
  .post .main-ttl.txt_l {
    margin-bottom: 1em;
    line-height: 1.3;
  }
  .post .main-ttl.txt_l::after {
    margin-left: 0;
    margin-right: auto;
  }

  .post h2::after {
    width: var(--px80w);
    height: 3px;
    margin-top: .7em;
    background: var(--color-font);
  }

  /* TOP */

  /* content01 */

  #content01 {
    padding:  0 ;
    background: var(--bg-FFFAD0);
    font-family: var(--font-family02);
  }
.lh2 {
  line-height: 2;
}

  .big-txt {
    font-size: var(--rem26w);
    letter-spacing: .12em;
    font-weight: 500;
    font-family: var(--font-family02);
    
  }
  #content01 p:not(.big-txt) {
    font-weight: 500;
    letter-spacing: .12em;
    line-height: 2.2;
	  position: relative;
	  z-index: 10;
  }
  #content01 .content-inner {
    padding: var(--px80) clamp(10px, calc(40px + ((1vw - 19.2px) * 1.9417)), 40px) calc(var(--px120s) - 5px);
    background: var(--bg-FFDF29);
    max-width: 955px;
	
  }
  .ttlico {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--px20);
  }

  #content01 .content-wrap {
    position: relative;
    margin: 0 auto;
    z-index: 0;

  }

  #content01 .content-wrap .corner-img {
    display: inline-block;
    position: absolute;
    z-index: 1;
  }
 
  #content01 .content-wrap .corner_img1 {
    top: var(--px20);
    left: 7px;
    width: 28%;
    max-width: clamp(150px, calc(527px + ((1vw - 19.2px) * 32.7541)), 527px);
  }
  #content01 .content-wrap .corner_img2 {
    top: 0;
    right: calc(clamp(10px, calc(16px + ((1vw - 19.2px) * 0.6696)), 16px) * -1);
    width: 27.5%;
    max-width: clamp(150px, calc(522px + ((1vw - 19.2px) * 32.3197)), 522px);
  }
  #content01 .content-wrap .corner_img3 {
    bottom: calc(calc(var(--px50) + 5px) * -1);
    left: clamp(10px, calc(100px + ((1vw - 19.2px) * 10.0446)), 100px);
    width: 26%;
    max-width: clamp(150px, calc(500px + ((1vw - 19.2px) * 30.4083)), 500px);
  }
  #content01 .content-wrap .corner_img4 {
    bottom: calc(calc(var(--px50) + 5px) * -1);
    right: var(--px24);
    width: 27%;
    max-width: clamp(150px, calc(515px + ((1vw - 19.2px) * 31.7116)), 515px);
  }

  #content01 .content-wrap .corner-img img {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
  }
@media print, screen and (max-width: 1023px) {
  #content01 .content-wrap .corner_img1 {
    top:5px;
    left: 5px;
  }
  #content01 .content-wrap .corner_img2 {
    top:5px;
    right: 0px;
  }
  #content01 .content-wrap .corner_img3 {
    /* bottom: -5px; */
    left: 5px;
  }
  #content01 .content-wrap .corner_img4 {
    /* bottom: -5px; */
    right: 5px;
  }
}
.blue-box {
  display: block;
  width: 100%;
  height: var(--px80);
  background: var(--color-background03);
}
  /* content02 */

#content02 {
  padding: var(--px40) 0 var(--px140);
  background: url(/wp-content/uploads/top-5.png) no-repeat center / cover;
  font-family: var(--font-family02);
}

#content02 .content-inner {
  max-width: 1260px;
}

/*------------------------------------------------------------
 ナンバリング01
------------------------------------------------------------*/
.num_list01 {
  counter-reset:number; /*数字をリセット*/
  list-style-type: none!important; /*数字を一旦消す*/
}
.num_list01 .imgarea {
	position: relative;
	margin-bottom: var(--px20);
}
.num_list01 .imgarea:before{
  /* 以下数字をつける */
    position: absolute;
    counter-increment: number;
    content: "0" counter(number);
    display: inline-block;
    background: url(/wp-content/uploads/top-union.png) no-repeat center / contain;
    color: var(--color-primary);
    font-family: var(--font-family03);
    font-weight: 700;
    font-style: italic;
    font-size: var(--rem70);
    letter-spacing: .06em;
    border-radius: 0;
    left: 0;
    width: clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px);
    height: clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px);
    line-height: clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px);
    text-align: center;
  top: calc(clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px) / -1.6);
    transform: translateX(0%);
    
}

.num_list01 .num_listttl {
    text-align: center;
    font-weight: bold;
    font-size: var(--rem22w);
    padding: .5em 0;
	position: relative;
  letter-spacing: .1em;
}
.card-info p:not(.num_listttl) {
  font-weight: 500;
  letter-spacing: .1em;
  font-size: var(--rem16);
}
/*---------col03-----------*/
  
.post .col3_list {
	position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	flex-wrap: wrap;
  align-items: stretch;
  padding-top: calc(clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px) / 1.5);
}
.post .col3_list > li {
    width: 32%;
    max-width: 390px;
	margin-bottom: 2%;
  background: var(--color-background);
  display: flex;
  flex-flow: column;
  justify-content: stretch;
  padding-bottom: var(--px35);
}
.post .col3_list::before {
    content: "";
    display: block;
    width: 32%;
    height: 0;
    order: 1;
}
.post .col3_list:after {
    content: "";
    display: block;
    width: 32%;
    height: 0;
}

.post .col3_list > li .txtarea {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
  height: 100%;
  padding: 0 var(--px24);
}
.post .col3_list > li .linkBtn {
  max-width: 189px;
  font-size: var(--px12);
  letter-spacing: .1em;
  padding: 1em 30px 1em 20px;
}

.post .col3_list > li .linkBtn:has(.arw) > .arw::before {
  content: url(/wp-content/uploads/arw-vector-sm.png);
}

.post .col3_list > li .linkBtn:has(.arw):hover > .arw::before {
  content: url(/wp-content/uploads/arw-vector-sm-prime.png);
}
@media print, screen and (min-width: 769px) {
  .num_list01 > li:first-child .imgarea:before,
	.num_list01 > li:nth-child(3n + 4) .imgarea:before {
    left: calc(var(--px18) * -1);
  }
}
@media print, screen and (max-width: 768px) {
	.post .col3_list > li {
		width: 49%;
    margin-bottom: calc(20px + calc(clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px) / 1.5));
    max-width: none;
	}
	.post .col3_list::before, .post .col3_list:after {
		content: none;
	}
/*   .post .col3_list > li:last-child {
		margin-bottom: 0;
	} */
}
@media print, screen and (max-width: 500px) {
	.post .col3_list > li {
		width: 100%;
	}
	.post .col3_list > li:last-child {
		margin-bottom: 0;
	}
}


.col3_grid, .post .col3_grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--px35);
}

.col3_grid .txtarea {
  padding: var(--px24) var(--px18);
}

.col3_grid .txtarea .card-ttl > p {
  text-align: center;
  font-size: var(--rem22w);
  font-weight: bold;
  letter-spacing: .14em;
color: var(--color-font01);
font-family: var(--font-family02);
}

.col3_grid .txtarea .card-ttl {
  margin-bottom: var(--px12);
}

.col3_grid .imgarea {
  overflow: hidden;
  aspect-ratio: 195 / 138;
  border-radius: var(--px30w);
}

.col3_grid .imgarea img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* btn */
.linkBtn, .post .linkBtn, a.linkBtn, .post .subimitarea .linkBtn input[type="submit"] {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 240px;
  font-size: var(--rem22w);
  color: var(--color-background);
  line-height: 1.8;
  letter-spacing: .1em;
  font-family: var(--font-family02);
  text-align: center;
  background: var(--color-background02);
  font-weight: bold;
  padding: var(--rem20) 30px var(--rem20) 20px;
  margin: var(--px40) auto 0;
  border: none;
  border-radius: var(--px100w);
  transition: all .3s;
  z-index: 99;
}
.post .linkBtn::after, .linkBtn::after, a.linkBtn::after {
  border-color: #fff;
}
.post .linkBtn:hover, .linkBtn:hover, a.linkBtn:hover, .post .subimitarea .linkBtn input[type="submit"]:hover {
  color:  var(--color-background02);
  background: var(--color-background);
outline: 1px solid var(--color-primary);
}
.post .linkBtn:hover::after, .linkBtn:hover::after, a.linkBtn:hover::after {
  border-color: #fff;
}
.subimitarea > .linkBtn {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
.post .subimitarea .linkBtn input[type="submit"] {
  margin-top: 0;
}

/* arw btn*/
.linkBtn:has(.arw) {
  max-width: 360px;
  padding: var(--rem16) 30px var(--rem16) 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: var(--px20);
}
.linkBtn:has(.arw)::after {
  content: none;
}

.linkBtn:has(.arw) > .arw {
  position: relative;
  display: inline-block;

}

.linkBtn:has(.arw) > .arw::before {
content: url(/wp-content/uploads/arw-vector.png);
display: block;
position: absolute;
left: 0;
top: -.2em;
transform: translateY(-50%);
}
.linkBtn:has(.arw):hover > .arw::before {
  content: url(/wp-content/uploads/arw-vector-prime.png);
}


/* content03 */

#content03 {
  position: relative;
  padding: var(--px130) 0;
  background: url(/wp-content/uploads/top-9.png) no-repeat center / cover;
}
#content03 .flexbox {
  justify-content: flex-end;
}
#content03 .flexbox .txtarea {
  
  max-width: 988px;
  width: 50%;
    padding: var(--px96) calc(clamp(20px, calc(100px + ((1vw - 19.2px) * 5.178)), 100px) + 6px) var(--px90) var(--px70);
  background: var(--bg-FFDF29);
  position: relative;
}
#content03 .flexbox .txtarea::before {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 151 / 90;
  width: 31%;
  height: auto;
  max-width: 302px;
  background: url(/wp-content/uploads/top-10.png) no-repeat center / contain;
  top: var(--px50);
  right: var(--px40);
}
.flx-l {
  justify-content: flex-start;
}
#content03 .ttlico {
  margin-bottom: 0;
  
  max-width: clamp(120px, calc(200px + ((1vw - 19.2px) * 5.178)), 200px);
}

#content03 .ttlico img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

#content03 .flexbox .txtarea .txtinner {
	display: flex;
	flex-flow: column;
justify-content: space-between;
	height: 100%;
	
}
@media print, screen and (min-width: 769px) {
  .pc_left .linkBtn:has(.arw) {
    margin-left: 0;
    margin-right: auto;
  }
}

.btn-group-sm {
  display: flex;
  justify-content: center;
  gap: var(--px30);
  
}

.btn-group-sm .linkBtn:has(.arw) {
  width: 100%;
  max-width: 285px;
  margin-right: 0;
  
}

.btn-group {
  width: 100%;
  max-width: 600px;
}

.btn-group .linkBtn.long-btn {
  width: 100%;
  max-width: none;
}

@media print, screen and (max-width: 768px) {
  #content03 .flexbox .txtarea {
    width: 100%;
    margin: 0 auto;
	  margin-bottom: 5%;
	  padding: var(--px96) var(--px40) var(--px90);
  }
	#content03 .flexbox .txtarea:last-child {
		margin-bottom: 0;
	}
}
@media print, screen and (max-width: 500px) {
  .btn-group-sm {
    flex-flow: column;
    gap: 0;
  }
  .btn-group-sm .linkBtn:has(.arw) {
    max-width: none;
  }
} 

/* insta */

#instagram {
  padding: var(--px130) 0 var(--px120);
  background: url(/wp-content/uploads/top-11.png) no-repeat center / cover;
}

#instagram .content-inner {
  max-width: 1600px;
	width: 90%;
}

#instagram .main-ttl, #instagram .main-ttl > .en-ttl {
  color: var(--color-background);
}
#instagram .main-ttl::after {
  background: var(--color-background);
}

#sb_instagram .sbi_follow_btn a {
	background: var(--color-background03) !important;
}

/* LOWER pages */

#thumbImg::before, header#h1Header::before {
  opacity: 0;
}

header#h1Header h1.title {
font-family: var(--font-family02);
text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
font-size: var(--rem48);
}

body:not(.home) #wrapper {
  width: 100%;
  max-width: none;
  background: url(/wp-content/uploads/lower-bg-e1744777323929.png) repeat-y top / contain;
  background-repeat: repeat-y;
    background-position-x: center;
    background-size: 100% auto;
}

body:not(.home) #content.wide {
  width: 90%;
  max-width: var(--content-max-width);
}
body:not(.home) .post {
  font-family: var(--font-family02);
  font-weight: 500;
}
body:not(.home) .post h2, .post h3, .post h4 {
  font-family: var(--font-family02);
  font-weight: bold;
  letter-spacing: .1em;
}

body:not(.home) .post h2 {
  font-size: var(--rem26w);
}

/* about */

#about-content .content01 p {
  font-size: 1.5rem;
}

/*--flow01--------------------------------------------*/
	
.flowlist01 {
	padding-left: 15rem;
	position: relative;
}
.flowlist01::before {
	content: "";
	width: 15px;
	height: 100%;
	background: var(--color-background03);
	margin-left: -8px;
	display: block;
	position: absolute;
	top: 0;
	left: 15rem;
}
.flowlist01 > li {
	position: relative;
}
.flowlist01 > li:not(:last-child) {
	margin-bottom: 8vh;
}
.flowlist01 > li .icon {
	font-size:2rem;
	color: #fff;
	font-family: var(--font-family02);
	font-weight: bold;
	background: var(--color-primary);
	padding: 0.8rem 2rem;
	display: block;
	position: absolute;
	top: 0;
	left: -22rem;
	z-index: 100;
	font-style: normal;
}
.flowlist01 > li .icon::after {
	content: "";
	border-style: solid;
	border-width: 5px 0 5px 10px;
	border-color: transparent transparent transparent var(--color-primary);
	position: absolute;
	top: 50%;
	left: 100%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.flowlist01 > li dl {
	padding-left: 7rem;
	position: relative;
	padding-top: 0.7rem;
}

.flowlist01 > li dl::before,
.flowlist01 > li dl::after {
	content: "";
	display: block;
	position: absolute;
	top: 2.4rem;
}
.flowlist01 > li dl::before {
	width: 7px;
	height: 7px;
	margin-top: 0;
	background: var(--color-background);
	border-radius: 50%;
	left: -4px;
}
.flowlist01 > li dl::after {
	width: 50px;
	border-bottom: 1px dashed var(--color-font);
	position: absolute;
	left: 5px;
	top: 2.7rem;
}
.flowlist01 > li dl dt {
	margin-bottom: 0.7rem;
	font-weight: 600;
	font-size: var(--rem24);
  font-weight: bold;
}

.flowlist01 > li dl dd:nth-child(2) {
  border-top: 1px solid var(--color-font);
  padding-top: .7rem;
}
@media (max-width: 768px) {
	.flowlist01 > li .icon {
		font-size: 1.2rem;
	}

	.flowlist01 {
		padding-left: 10rem;
	}

	.flowlist01 > li .icon {
		left: -11rem;
	}

	.flowlist01::before {
		left: 10rem;
	}

	.flowlist01 > li dl {
		padding-left: 4.5rem;
	}

	.flowlist01 > li dl::after {
		width: 30px;
	}

	.flowlist01 > li dl dt {
		font-size: 1.4rem;
	}
	.flowlist01 > li dl::before,
	.flowlist01 > li dl::after{
		top:2rem;
	}
	.flowlist01 > li dl::after {
		top:2.3rem;
	}
}

.post table th {
  background: var(--color-primary);
  color: var(--color-background);
  font-weight: bold;
}
.post table.responsive {
  border: 0;
  border-collapse: separate;
  border-spacing: 0 2px;
}
.post table.responsive th,
.post table.responsive td {
  border-color: var(--color-primary);
  font-size: var(--rem16);
}

.post table.w5-5 th, table.w5-5 th {
width: 50%;
}

table.w5-5 th ,
table.w5-5 td {
  text-align: center;
  vertical-align: middle;
  padding: 2em 1em;
}

.straight-letter {
  display: inline-block;
  min-width: 7em;
  text-align: right;
}

@media screen and (max-width: 1024px) {
  .post table.responsive th, .post table.responsive td {
      text-align: center;
  }
}

@media screen and (max-width: 1023px) {
  .post table.responsive th, .post table.responsive td {
      text-align: left;

  }
  
.post table.w5-5 th {
  width: auto;
  min-width: fit-content;
}
}

/* service */

.post h3 {
  font-size: var(--rem20w);
 border-color: var(--color-font);
}
.big-ttl {
	background:inherit;
	position: relative;
	padding:0;
	overflow: inherit;
	padding-bottom: 0.5rem;
	padding-top: 0.5rem;
	margin: 0 0 3rem;
	padding: 0;
	font-size: var(--rem24);
	
	line-height: 1.4;
  color: var(--color-primary);
}
.big-ttl::after {
  content: none;
}
.big-ttl > span {
	position: relative;
	display: inline-block;
	padding: 0 2.5em;
}
.big-ttl > span::before,
.big-ttl > span::after{
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: 2em;
	height: .25em;
	background-color: var(--clr-3DAEFF);
}
.big-ttl > span::before {
	left:0;
	-moz-transform: rotate(60deg);
	-webkit-transform: rotate(60deg);
	-ms-transform: rotate(60deg);
	transform: rotate(60deg);
}
.big-ttl > span::after {
	right: 0;
	-moz-transform: rotate(-60deg);
	-webkit-transform: rotate(-60deg);
	-ms-transform: rotate(-60deg);
	transform: rotate(-60deg);
}
.big-ttl span span {
	display: block;
	color: var(--color-primary-shade);
	font-size: 1.8rem;
	margin-top: 0.5rem;
}

.col2_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--px20);
  justify-content: center;
}

body:not(.home) .linkBtn {
  font-size: var(--rem18);
}

.wpcf7-form .must {
    background: var(--clr-3DAEFF);
}

/* 20250512 */
@media print,
screen and (min-width: 769px) {
    .post .col3_list {
        row-gap: calc(clamp(70px, calc(143px + ((1vw - 19.2px) * 4.7249)), 143px) / 1.6);
    }
}

#content03:before {
    content: "";
    display: block;
    position: absolute;
    background: var(--color-background);
    inset: 0;
    opacity: .2;
}

#content03 .content-wrap {
    position: relative;
    z-index: 1;
}

#content03 .flexbox .txtarea {
    background: #FFFFFFCC;

}

#content03 .flexbox {
    gap: var(--px40);
    align-items: stretch;
}

#content03 .content-inner {
    max-width: 1660px;
}

#content03 .flexbox .txtarea::before {
    top: var(--px24);
    right: var(--px24);
}

#content03 .flexbox .txtarea:first-child:before {
    background: url(/wp-content/uploads/top-11-1.png) no-repeat center / contain;
    aspect-ratio: 214 / 199;
}

@media print,
screen and (min-width: 769px) {
    #content03 .flexbox .txtarea {
        padding-left: clamp(30px, calc(70px + ((1vw - 19.2px) * 3.4752)), 70px);
    }

    #content03 .main-ttl>.en-ttl {
        font-size: clamp(36px, calc(7rem + ((1vw - 19.2px) * 2.954)), 70px);
    }
}

#instagram {
    background: var(--bg-FFFAD0);
    color: var(--color-font);
}

#instagram .main-ttl,
#instagram .main-ttl>.en-ttl {
    color: var(--color-font);
}

#instagram .main-ttl::after {
    background: var(--color-font);
}

#instagram .main-ttl {
    padding-left: calc(var(--px120s) + 1em);
    display: inline-block;

}

#instagram .content-inner {
    display: flex;
    align-items: center;
    flex-flow: column;
}
#instagram .main-ttl::before {
    content: "\f16d";
    display: inline-block;
    font-family: "FontAwesome";
    font-size: calc(var(--px120s) + 5px);
    font-weight: normal;
    position: absolute;
    left: 0;
    top: 0;
    line-height: 1;
    background: linear-gradient(45deg, #feda75, #fa7e1e, #d62976, #962fbf, #4f5bd5);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent; /* for Firefox */
}


.cta01 {
    background: var(--bg-FFDF29);
}

.cta01 .cta-img01 {
    display: none;
}

.cta01 .cta01_wrap {
    padding-bottom: var(--px80);
}

/* content04 */
#content04 p {
    font-family: var(--font-family02);
}

#content04 {
    position: relative;
    /*  padding: 0 0 var(--px120);  */
    background: var(--bg-FFDF29);
}

#content04 .flexbox .imgarea iframe {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 620 / 403;
}

#service-content .content01 .flexbox .imgarea img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.col2_grid .img-contain img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.big-txt,
#about-content .content01 .big-txt {
    font-size: var(--rem30);
    color: var(--color-primary);
    font-weight: 800;
    line-height: 1.4;
    padding-bottom: 1em;
    margin-bottom: 1em;
    border-bottom: 1px solid var(--color-font);
}

.page-about p,
.page-about li {
    font-size: var(--rem18);
}

.tag-name {
    display: inline-block;
    padding: .5em;
    color: var(--color-background);
    background: var(--color-primary);
    font-size: var(--rem18);
    margin-bottom: .5em;

}

.post h2.ttl-02::after {
    content: none !important;
}

.post h2.ttl-02 {
    text-align: left;
    font-size: var(--rem24w);
    line-height: 2;
    border-left: var(--rem16) solid var(--clr-3DAEFF);
    padding-left: .5em;
    margin-top: 0;
    margin-bottom: 1.1em;
}

.post ul.list_point>li,
.post ul.list_check>li,
.post ul.caution>li,
.post ul.list_checkbox>li {
    padding-left: 2em;
}

.col4_circle {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--px20);
}

.col4_circle>li .txtarea {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--px12);
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background: var(--bg-FFFAD0);
    width: 100%;
    height: auto;
}

.circle-txt,
.post .circle-txt {
    font-weight: bold;
    font-size: var(--rem22w);
    text-align: center;
}

@media print,
screen and (max-width: 600px) {
    .col4_circle {
        grid-template-columns: repeat(2, 1fr);
    }

    .circle-txt,
    .post .circle-txt {
        font-size: var(--rem18);
    }
}

.caution-txt,
.post .caution-txt {
    font-weight: bold;
    font-size: var(--rem22w);
    margin: var(--px50) 0;
}


.post ol li {
    padding-left: 1em;
}

.straight-letter {
    min-width: 5em;
    text-align: center;
}

table.col3 th,
table.col3 td {
    text-align: center;
    vertical-align: middle;
    padding: 2em 1em;
}

table.w5-5 th,
table.w5-5 td,
table.col3 th,
table.col3 td {
    padding: .5em .5em;
    height: 5em;
}

.post table thead th {
    font-size: var(--rem18);
    padding: 1.2em 1em;
    height: auto;
}

table.col3 tbody th {
    width: 30%;
    min-width: fit-content;
    max-width: fit-content;
}

.post table.w5-5 th,
table.w5-5 th {
    width: 52%;
}

.flexbox:has(.tablearea) {
    gap: var(--px14);
}

table.col3 tbody td:not(:last-child) {
    width: 54%;
}

.tablearea {
    overflow-x: auto;
}

.tablearea table.col3 {
    min-width: 450px;
}

@media print,
screen and (min-width: 768px) {
    .mbbr {
        display: none;
    }
}

.box-clr {
    padding: var(--px40);
}

.bg-FFFAD0 {
    background: var(--bg-FFFAD0);
}

.rating-ttl,
.post .rating-ttl {
    font-weight: bold;
    font-size: var(--rem18);
    padding-bottom: 1em;
    margin-bottom: 1em;
    border-bottom: 1px dashed var(--color-font);
}

.rating-ttl>span {
    margin-left: 1em;
}

body:not(.home) .long-btn {
    max-width: 600px;
}

.gallery-wrap .flexbox{
	align-items: stretch;
	
}

#gallery-1 img, #gallery-2 img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#gallery-1 img {
	max-width: 100%;
}
#gallery-2 {
	row-gap: var(--px20);
	align-items: stretch;
	height: 100%;
}
#gallery-2 .gallery-icon {
	height: 100%;
}
#gallery-1 .gallery-item , #gallery-2 .gallery-item {
	margin-bottom: 0;
	
}
/*
#gallery-1 .gallery-item {
	width: 100% !important;
}
*/
@media screen and (max-width: 768px) {
    .content-inner>div.flexbox.rev.ai_center.pt10 {
        display: flex;
        flex-direction: column-reverse !important;
    }
}
.custom-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 幅指定 */
  gap: 16px;
  justify-content: center; /* 真ん中揃え */
max-width: calc(294px * 2 + 16px);
	margin: 0 auto;
	margin-top: var(--px40) !important;
}
.custom-gallery > a{
	display: block;
	max-width: 294px;
	aspect-ratio: 294 / 180;
}
.custom-gallery img {
  width: 100%;
height: 100%;
  
  object-fit: cover;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .custom-gallery {
    grid-template-columns: repeat(2, 1fr); /* 比率で2列 */
    gap: 12px;
  }

  .custom-gallery img {
    width: 100%;
    height: auto;
    aspect-ratio: 294 / 180;
  }
}

/*----20250523---*/
.flowlist01 > li .icon2::after {
    top: 29%;
}

.flowlist01 > li .icon {
	font-size: clamp(14px, 1.129vw - -5.31px, 20px) !important;
	@media screen and (max-width: 1300px) {
        left: -21rem;
	}
	@media screen and (max-width: 1250px) {
        left: -21rem;
	}
	@media screen and (max-width: 1200px) {
        left: -20rem;
	}
	@media screen and (max-width: 1024px) {
        left: -19rem;
	}
	@media screen and (max-width: 880px) {
        left: -18rem;
	}
	@media screen and (max-width: 768px) {
        left: -11rem;
	}
	@media screen and (max-width: 768px) {
		padding: 0.8rem 0.5rem !important;
		font-size: 10px !important;
	}
}
#content04 {
    background: white !important;
}
  #header ul.header__contact li{
    padding: 5px !important;
  }
/* nav#mainNav ul li a {
    padding-left: 15px !important;
} */
.mt_none{
	margin-top:10px !important;
}
/*20250528*/
/* ボタン全体を囲っている親要素に適用（例：.button-groupなど） */
.button-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px; /* ボタン同士の間隔 */
  margin-bottom: 20px; /* 1段目と2段目の間の空白 */
}

/* 各ボタンのスタイル */
.button-group button {
  flex: 1 1 auto; /* ボタンを適度に伸縮させる */
  min-width: 200px; /* スマホ時に縦並びでも読みやすい幅 */
}
@media screen and (max-width: 1023px) {
  nav#mainNav ul li.menu-item-has-children > a {
    padding-right: 2rem; /* ←矢印の分スペース確保 */
  }
}
/*20250529*/
#instagram .highlights-flex {
    display: flex;
    width: 100%;
    justify-content: space-evenly;
}
@media screen and (max-width: 768px) {
  #instagram .highlights-flex {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }
}

    #gallery-1 {
        gap: 1rem;

        &.gallery-columns-3 {
            .gallery-item {
                width: calc((100% - 2rem) / 3) !important;
            }
        }
    }
    #gallery-2 {
        row-gap: 10px;

        &.gallery-columns-2 {
            .gallery-item {
                width: calc((100% - 10px) / 2) !important;
            }
        }
    }

    .gallery-columns-2 .gallery-item img {
        max-width: 100% !important;
    }