@charset "utf-8";
/* CSS Document */

/*==================================================
 common
==================================================*/
:root {
  --height_header: 0;
  --height_fix_footer: 0px;
  --section: 100px;

  --base_width: 1100px;
  --base_minwidth: 680px;
  --base_midwidth: 780px;
  --base_color: var(--black);
  --base_bg: var(--white);

  --font_jp: "Zen Kaku Gothic New", sans-serif;
  --font_en: "Jost", sans-serif;
  --icons: "Material Symbols Outlined";
  --iconsfill: "FILL" 1; /*塗りつぶしアイコン font-variation-settings: var(--iconsfill);*/

  --transition: 0.3s;
  --bold: bold;

  --black: #1f1f1f;
  --white: #ffffff;
  --gray: #cfcfcf;

  --orange: #d97a50;
  --Lorange: #fbf9f7;
  --linegreen: #06c755;
}
@media (max-width: 520px) {
  :root {
    --section: 50px;
    --base_width: 100%;
    --base_minwidth: 100%;
    --base_midwidth: 100%;
  }
}

html {
  scroll-padding-top: 80px;
}
body {
  position: relative;
  padding-top: var(--height_header);
  background: url(../images/top_bg1.webp) no-repeat top center / max(100%, 1440px) auto;
  line-height: 1.8;
}
body:not(.home) {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.6) 0%, rgba(255, 255, 255, 0.6) 100%),
    url(../images/top_bg1.webp) no-repeat top -150px center / max(100%, 1440px) auto;
}

@media screen and (max-width: 520px) {
  html {
    scroll-padding-top: 56px;
  }
  body {
    background-size: 200% auto;
  }
  body:not(.home) {
    background-position: center top / top -50px center;
    background-size: 100% 100% / 200% auto;
  }
}

/*----------------------------------------
  base control
----------------------------------------*/

/* objedt-fit */
.of_cover img,
img.of_cover {
  object-fit: cover;
}

.of_cont img,
img.of_cont {
  object-fit: contain;
}

body .calc_pr_min {
  padding-right: max(5%, calc((100vw - var(--base_minwidth)) / 2));
}
body .calc_pl_min {
  padding-left: max(5%, calc((100vw - var(--base_minwidth)) / 2));
}

@media screen and (max-width: 520px) {
  body .calc_pr_min {
    padding-right: 5%;
  }
  body .calc_pl_min {
    padding-left: 5%;
  }
}

/*----------------------------------------
  box control
----------------------------------------*/

/* [class*="grid_"] 等分 */
[class*="grid_"] {
  display: grid;
  grid-template-columns: repeat(var(--grid), 1fr);
  gap: var(--gap);
  --grid: 3;
  --gap: 50px;
}
@media (max-width: 520px) {
  [class*="grid_"] {
    --gap: 30px;
    --grid: 1;
  }
}

/* [class*="grid_"] 等分 auto-fit*/
[class*="gridfit_"] {
  display: grid;
  grid-template-columns: repeat(auto-fit, var(--width));
  justify-content: center;
  gap: var(--gap);
  --grid: 3;
  --gap: 50px;
  --width: calc((100% - var(--gap) * (var(--grid) - 1)) / var(--grid));
}

/* [class*="flexnum_"] 等分 */
[class*="flexnum_"] {
  display: flex;
  flex-flow: wrap;
  gap: var(--gap);
  --num: 3;
  --gap: 60px;
  --width: calc((100% - var(--gap) * (var(--num) - 1)) / var(--num));
}

[class*="flexnum_"] > * {
  width: var(--width);
}

@media screen and (max-width: 520px) {
  [class*="flexnum_"] {
    --num: 1;
    --gap: 20px;
  }
}

/* [class*="flexfit_"] 1個：1列 / 偶数：2列 奇数：3列 可変*/
[class*="flexfit_"] {
  display: flex;
  flex-flow: wrap;
  gap: var(--gap);
  --gap: 60px;
}
/*1以外奇数 */
[class*="flexfit_"] > * {
  --num: 3;
  --width: calc((100% - var(--gap) * (var(--num) - 1)) / var(--num));
  width: var(--width);
}
/* 1個 */
[class*="flexfit_"]:has(> *:only-child) > * {
  --num: 1;
}
/* 偶数 */
[class*="flexfit_"]:has(> *:nth-child(even):last-child) > * {
  --num: 2;
}

/* [class*="alternating_"] 交互の */
[class*="altern_"] {
  display: flex;
  flex-flow: column;
  gap: var(--gaps);
  --gaps: 100px; /*親縦gap*/
  --gap: 60px; /*子横gap*/
  --firstchild: 55%; /*子メディア幅*/
}
[class*="altern_"] > * {
  display: flex;
  gap: var(--gap);
}
[class*="altern_"] > * > *:first-child {
  flex: none;
  width: var(--firstchild);
}
[class*="altern_"] > * > *:last-child {
  flex: 1;
}

[class*="altern_"] > *:nth-child(even) {
  flex-flow: row-reverse;
}

@media screen and (max-width: 520px) {
  [class*="altern_"] {
    --gaps: 50px; /*親縦gap*/
    --gap: 20px; /*子横gap*/
    --firstchild: 100%; /*子メディア幅*/

    --alternff: column; /*スマホのみ並び*/
  }
  [class*="altern_"] > * {
    flex-flow: var(--alternff);
  }
  [class*="altern_"] > *:nth-child(even) {
    flex-flow: var(--alternff);
  }
}

/* [class*="Horizontal_"] 水平（つまり左右）*/
[class*="horizon_"] {
  display: flex;
  gap: var(--gap);
  flex-flow: var(--horizonff);
  --gap: 60px; /*横gap*/
  --horizonff: row; /*並び*/
  --firstchild: 55%; /*メディア幅*/
}
[class*="horizon_"] > *:first-child {
  flex: none;
  width: var(--firstchild);
}
[class*="horizon_"] > *:last-child {
  flex: 1;
}

@media screen and (max-width: 520px) {
  [class*="horizon_"] {
    --gap: 20px; /*横gap*/
    --horizonff: column; /*並び*/
    --firstchild: 100%; /*メディア幅*/
  }
}

/*==================================================
 this site specific
==================================================*/

/*----------------------------------------
  title
----------------------------------------*/

.tit_page {
  padding-top: 50px;
  padding-bottom: 50px;
}

.tit_A {
  grid-area: titA;
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 0;
  margin: 0 auto 30px;
  border: none;
  border-radius: 0;
  background: none;
  color: var(--base_color);
  font-size: 3.4rem;
  font-weight: var(--bold);
  line-height: 1.5;
  text-align: left;
}

.tit_A i {
  display: block;
  color: var(--orange);
  font-family: var(--font_en);
  font-size: 0.5em;
  font-style: normal;
  line-height: 1.3;
  text-transform: uppercase;
}
.tit_A.t_L {
  align-items: flex-start;
  margin: 0;
}

.tit_B {
  margin: 40px auto 15px;
  color: var(--orange);
  font-size: 2.4rem;
  text-align: center;
  font-weight: var(--bold);
}

.tit_C {
  margin: 40px auto 15px;
  color: var(--black);
  font-size: 2.4rem;
  text-align: left;
  font-weight: var(--bold);
}

@media screen and (max-width: 520px) {
  .tit_page {
    padding-top: 25px;
    padding-bottom: 25px;
  }

  .tit_A {
    font-size: 2.4rem;
  }

  .tit_B {
    font-size: 1.8rem;
  }
}

/*----------------------------------------
  button
----------------------------------------*/

:is(.btn_A, .btn_B) {
  grid-area: btnA;
  position: relative;
  display: block;
  width: min(80vw, 320px);
  margin: 40px auto;
  padding: 15px 2em 15px 1em;
  border-radius: 50px;
  text-align: center;
}
:is(.btn_A, .btn_B):after {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  content: "arrow_forward";
  font-family: var(--icons);
}

.btn_A {
  background: var(--orange);
  border: 1px solid var(--orange);
  color: var(--white);
}
.btn_A:hover {
  background: var(--white);
  border: 1px solid var(--orange);
  color: var(--orange);
}

.btn_B {
  background: var(--white);
  border: 1px solid var(--white);
  color: var(--orange);
}
.btn_B:hover {
  background: var(--orange);
  border: 1px solid var(--white);
  color: var(--white);
}

@media screen and (max-width: 520px) {
  :is(.btn_A, .btn_B) {
    margin: 30px auto 15px;
  }
}

/**アイコンボタン**/
.icon_before:before {
  content: "";
  display: block;
  width: var(--size);
  height: auto;
  aspect-ratio: var(--ar);
  -webkit-mask: var(--mask);
  mask: var(--mask);
  background-color: currentColor;
}

.link_line {
  grid-area: line;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 10px 20px;
  background: var(--linegreen);
  border-radius: 5px;
  color: var(--white);
  text-align: center;
}

.link_line.icon_before:before {
  --size: 1.5em;
  --ar: 1/1;
  --mask: url(../images/icon_line.svg) center center / contain no-repeat;
}

.link_tel {
  grid-area: tel;
  display: block;
}

.link_tel span {
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font_en);
  font-size: 3rem;
  font-weight: normal;
  white-space: nowrap;
  line-height: 1;
}
.link_tel .icon_before:before {
  --size: 0.7em;
  --ar: 1/1.5;
  --mask: url(../images/icon_tel.svg) center center / contain no-repeat;
}
.link_tel p {
  font-size: 1.3rem;
  padding-left: 2em;
}

@media screen and (max-width: 520px) {
  .link_line {
    grid-area: line;
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 10px 50px;
    background: var(--linegreen);
    border-radius: 5px;
    color: var(--white);
  }
  .link_tel {
    text-align: center;
  }
  .link_tel span {
    justify-content: center;
    font-size: 3.2rem;
  }
}

/*----------------------------------------
  トグル
----------------------------------------*/
.toggle {
  display: none;
}
.toggle + .click::after {
  transform: rotate(90deg);
}
.toggle + .click + .open {
  height: 0;
  padding: 0 20px;
  text-align: center;
  overflow: hidden;
  transition: var(--transition);
}
.toggle:checked + .click + .open {
  /*開閉時*/
  height: auto;
  padding: 20px;
  transition: var(--transition);
}

/*==================================================
header
==================================================*/
header {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 100;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  width: 100%;
  min-width: var(--base_width);
  padding: 10px 2%;

  animation: changeColor linear;
  animation-timeline: scroll();
}

@keyframes changeColor {
  0% {
    background-color: transparent;
  }
  0.1%,
  100% {
    background-color: var(--white);
  }
}

header .logo {
  display: flex;
  align-items: center;
}

header .logo img {
  width: 320px;
  height: auto;
}

header nav {
  flex: 1;
  padding: 0;
}

header nav .gnav {
  display: grid;
  grid-template-columns: 1fr repeat(2, auto);
  grid-template-areas: "tel ul line";
  align-items: center;
  gap: 20px;
}

header nav .gnav ul {
  grid-area: ul;
  display: flex;
  align-items: center;
  gap: 20px;
}

header nav .gnav ul a:hover {
  color: var(--orange);
  opacity: 1;
}

.hamburger,
#hamburger-check {
  display: none;
}

@media screen and (max-width: 520px) {
  header {
    height: 56px;
    padding: 0 0 0 10px;
  }

  header .logo img {
    width: 240px;
    margin: 0;
  }

  .hamburger {
    position: fixed;
    top: 5px;
    right: 10px;
    z-index: 90;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 44px;
    width: 44px;
    background: var(--orange);
    border-radius: 100vw;
  }

  #hamburger-check {
    display: none;
  }

  /**タップされる前 open**/
  .hamburger span,
  .hamburger span:before,
  .hamburger span:after {
    content: "";
    position: absolute;
    display: block;
    height: 2px;
    width: 20px;
    border-radius: 3px;
    background-color: var(--white);
  }

  .hamburger span:before {
    bottom: 6px;
  }

  .hamburger span:after {
    top: 6px;
  }

  /**タップされたとき close**/
  #hamburger-check:checked ~ .hamburger span {
    background-color: rgba(255, 255, 255, 0);
  }

  #hamburger-check:checked ~ .hamburger span::before {
    bottom: 0;
    transform: rotate(45deg);
  }

  #hamburger-check:checked ~ .hamburger span::after {
    top: 0;
    transform: rotate(-45deg);
  }

  header nav .gnav {
    position: fixed;
    top: 0;
    left: 100%;
    /*leftの値を変更してメニューを画面外へ*/
    z-index: 80;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: flex-start;
    gap: 40px;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 100px 20px 20px;
    background-color: var(--Lorange);
    font-size: 1.2em;
    overflow-y: auto;
    overflow-x: hidden;
    transition: var(--transition);
  }

  #hamburger-check:checked ~ .gnav {
    left: 0;
  }

  header nav .gnav ul {
    flex-flow: column;
    align-items: flex-start;
  }
}

.sp_fixed {
  display: none;
}

@media screen and (max-width: 520px) {
  .sp_fixed {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 100;
    display: flex;
    width: 100%;
    background: var(--white);
  }

  .sp_fixed .link_tel {
    padding: 10px;
    background: var(--orange);
    color: var(--white);
  }

  .sp_fixed .link_tel span {
    font-size: 1.8rem;
    font-family: var(--font_jp);
  }
  .sp_fixed .link_tel p {
    padding: 0;
  }

  .sp_fixed .link_line {
    flex: 2;
    padding: 10px;
    border-radius: 0;
  }
}

/*==================================================
 footer
==================================================*/
footer {
  display: grid;
  grid-template-columns: 400px 1fr 260px;
  grid-template-areas:
    "logo sitemap line"
    "p . ."
    "tel . pry";
  align-items: center;
  gap: 15px 30px;
  width: var(--base_width);
  margin: 0 auto;
  padding: 50px 0;
  background: var(--white);
}

footer .logo {
  grid-area: logo;
}

footer .logo img {
  width: 320px;
  height: auto;
}

footer p {
  grid-area: p;
  font-size: 1.5rem;
}

footer .sitemap {
  grid-area: sitemap;
  display: flex;
  justify-content: flex-end;
  gap: 20px;
}

footer .sitemap a:hover {
  color: var(--orange);
}

footer .privacy {
  grid-area: pry;
  margin: auto 0 0 auto;
}

.copyright {
  font-size: 1.2rem;
  text-align: center;
  padding: 20px 0;
}

@media screen and (max-width: 520px) {
  footer {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "logo"
      "p"
      "tel"
      "sitemap"
      "line"
      "pry";
    align-items: center;
    justify-content: center;
    gap: 15px 30px;
    width: var(--base_width);
    margin: 0 auto;
    padding: 25px 5%;
    background: var(--white);
    text-align: center;
  }

  footer .logo {
    grid-area: logo;
  }

  footer .logo img {
    width: 320px;
    height: auto;
  }

  footer p {
    grid-area: p;
    font-size: 1.5rem;
  }

  footer .sitemap {
    grid-area: sitemap;
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    gap: 20px;
    margin: 30px auto 0;
    font-size: 1.4rem;
  }

  footer .sitemap a:hover {
    color: var(--orange);
  }

  footer .privacy {
    grid-area: pry;
    margin: 30px auto 0;
    font-size: 1.4rem;
  }

  .copyright {
    font-size: 1.2rem;
    text-align: center;
    padding: 20px 0 80px;
  }
}

/*==================================================
TOPページ 
==================================================*/
/*----------------------------------------
  mv
----------------------------------------*/
.sec-mv {
  padding: 70px 0 90px;
}

.sec-mv h1 {
  font-size: 4.2rem;
  font-weight: var(--bold);
  margin: 0 auto 60px;
  text-align: right;
}

.sec-mv .splide ul > *:nth-child(even) {
  margin: 80px 0 0;
}

@media screen and (max-width: 520px) {
  .sec-mv {
    padding: 35px 0 45px;
  }
  .sec-mv h1 {
    font-size: 2.4rem;
    margin: 0 auto 30px;
  }
  .sec-mv .splide ul > *:nth-child(even) {
    margin: 40px 0 0;
  }
}

/*----------------------------------------
  concept
----------------------------------------*/
.sec-concept {
  padding-bottom: 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "titA dl"
    "tit dl"
    "fig dl";
  gap: 20px 30px;
  width: var(--base_width);
  margin: 0 auto;
}

.sec-concept figure {
  grid-area: fig;
}

.sec-concept dl {
  grid-area: dl;
}

.sec-concept dl dt {
  margin-top: 30px;
  margin-bottom: 5px;
  color: var(--orange);
  font-size: 2.8rem;
  font-weight: var(--bold);
  letter-spacing: -0.05em;
}

@media screen and (max-width: 520px) {
  .sec-concept {
    padding-bottom: 40px;
    grid-template-columns: 1fr;
    grid-template-areas:
      "titA"
      "tit"
      "fig"
      "dl";
    gap: 5px;
    width: 90%;
    margin: 0 auto;
  }

  .sec-concept .tit_A {
    align-items: center;
  }

  .sec-concept figure {
    margin: 15px 0 0;
  }

  .sec-concept dl dt {
    margin-top: 20px;
    font-size: 2.2rem;
    text-align: center;
  }
}

/*----------------------------------------
  care
----------------------------------------*/
.sec-care {
  padding-top: 70px;
  padding-bottom: 70px;
  background: var(--Lorange);
}

.sec-care ul {
  columns: 2;
  margin: 0 auto;
  width: fit-content;
}

@media screen and (max-width: 520px) {
  .sec-care {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .sec-care ul {
    columns: 1;
  }
}

/*----------------------------------------
  massege
----------------------------------------*/
.sec-message {
  padding-top: 70px;
  padding-bottom: 400px;
  background: url(../images/top_bg2.webp) no-repeat center bottom / 100% auto;
}

@media screen and (max-width: 520px) {
  .sec-message {
    padding-top: 40px;
    padding-bottom: 280px;
    background-size: 200% auto;
  }
}

/*----------------------------------------
 privacy
----------------------------------------*/
.sec-page {
  padding-bottom: 100px;
}

@media screen and (max-width: 520px) {
  .sec-page {
    padding-bottom: 50px;
  }
}

/*----------------------------------------
company
----------------------------------------*/
.dl_A {
  display: flex;
  flex-flow: wrap;
}

.dl_A dt {
  width: 30%;
  font-weight: var(--bold);
  font-size: 1.8rem;
}
.dl_A dd {
  width: 70%;
}

.dl_A :is(dt, dd) {
  padding: 15px 20px;
}

@media screen and (max-width: 520px) {
  .dl_A dt {
    width: 100%;
  }
  .dl_A dd {
    width: 100%;
    margin: 0 0 20px;
  }

  .dl_A :is(dt, dd) {
    padding: 5px 0;
  }
}

/*----------------------------------------
care  
----------------------------------------*/
.sec-plan {
  padding-bottom: 100px;
}

.dl_B {
  width: var(--base_midwidth);
  margin: 70px auto;
}

.dl_B dt {
  margin: 40px 0 10px;
  font-size: 2rem;
  font-weight: var(--bold);
}

.dl_B dd {
  padding-left: 2.5em;
}

.box-care {
  width: calc(var(--base_midwidth) + 60px);
  margin: 0 auto;
  padding: 40px 60px;
  border: 1px solid var(--gray);
}

@media screen and (max-width: 520px) {
  .sec-plan {
    padding-bottom: 50px;
  }

  .sec-plan .tit_B {
    margin: 0 auto;
    text-align: left;
  }

  .dl_B {
    margin: 35px auto;
  }

  .dl_B dt {
    margin: 20px 0 10px;
    font-size: 1.8rem;
  }

  .dl_B dd {
    padding-left: 1em;
  }

  .box-care {
    width: var(--base_midwidth);
    padding: 25px;
    font-size: 1.5rem;
  }
}

/*
  getting care
----------------------------------------*/

.sec-getting {
  padding-top: 70px;
  padding-bottom: 70px;
  background: color-mix(in srgb, var(--Lorange) 100%, var(--orange) 5%);
}

.sec-getting .tit_A {
  margin: 0 auto 40px;
}

.dl_C {
  width: calc(var(--base_midwidth) + 60px);
  margin: 0 auto 30px;
  padding: 40px 60px;
  background: var(--white);
}

.dl_C dt {
  margin: 0 0 10px;
  color: var(--orange);
  font-size: 2.2rem;
  font-weight: bold;
}

.dl_C h3 {
  width: fit-content;
  margin: 20px 0 10px;
  padding: 5px 20px;
  background: var(--orange);
  border-radius: 50px;
  color: var(--white);
  font-size: 1.7rem;
}

.dl_C strong {
  font-weight: var(--bold);
}

@media screen and (max-width: 520px) {
  .dl_C {
    width: var(--base_midwidth);
    padding: 25px;
  }
}

/*
  price
----------------------------------------*/
.sec-price {
  padding-top: 70px;
  padding-bottom: 100px;
  background: var(--Lorange);
}

.box-price {
  width: calc(var(--base_midwidth) + 60px);
  margin: 40px auto 0;
  padding: 20px 60px;
  background: var(--white);
  color: var(--black);
}

@media screen and (max-width: 520px) {
  .box-price {
    padding-top: 40px;
    padding-bottom: 40px;
    width: var(--base_midwidth);
    padding: 25px;
  }
  .box-price .tit_B {
    margin: 0 auto 15px;
  }
}

/*
  flow
----------------------------------------*/
.sec-flow {
  padding-top: 70px;
  padding-bottom: 400px;
  background: url(../images/top_bg2.webp) no-repeat center bottom / 100% auto;
}

.sec-flow_inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}

.sec-flow_inner .tit_A {
  flex: none;
  width: 250px;
  align-items: flex-start;
}

.ol-flow {
  margin: 0 0 40px;
}

.ol-flow li {
  counter-increment: number;
  display: flex;
  flex-flow: wrap;
  align-items: center;
  gap: 15px 20px;
}

.ol-flow li + li {
  margin-top: 40px;
}

.ol-flow em {
  display: flex;
  align-items: flex-end;
  gap: 0.5em;
  color: var(--orange);
  font-family: var(--font_en);
  font-weight: bold;
}
.ol-flow em:after {
  content: counter(number, decimal-leading-zero);
  font-size: 4.2rem;
  line-height: 1;
}

.ol-flow h3 {
  margin: 0 0 5px;
  color: var(--orange);
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1.3;
}

.ol-flow li p {
  width: 100%;
}

@media screen and (max-width: 520px) {
  .sec-flow {
    padding-top: 40px;
    padding-bottom: 280px;
    background-size: 200% auto;
  }

  .sec-flow_inner {
    flex-flow: column;
    gap: 0;
  }

  .sec-flow_inner .tit_A {
    align-items: center;
  }

  .ol-flow {
    margin: 0;
  }
}

/*----------------------------------------
  contact
----------------------------------------*/
.sec-contact {
  padding-bottom: 100px;
}

.sec-contact .tit_C {
  margin-top: 0;
  font-size: 2rem;
}

:is(.box-tel, .box-line) {
  width: calc(var(--base_midwidth) + 60px);
  margin: 40px auto 0;
  padding: 40px;
  border-radius: 5px;
  text-align: center;
}

:is(.box-tel, .box-line) .tit_A {
  padding: 20px 0;
  background: var(--white);
  border-radius: 5px;
  font-size: 2.6rem;
}

.box-tel {
  background: var(--orange);
  color: var(--white);
}
.box-tel .link_tel {
  margin: 20px auto;
}
.box-tel .link_tel span {
  justify-content: center;
  font-size: 4rem;
}

.box-line {
  background: var(--linegreen);
  color: var(--white);
}
.box-line .tit_A i {
  color: var(--linegreen);
}
.box-line .link_line {
  margin: 30px auto 0;
  width: min(80vw, 320px);
  border: 1px solid var(--white);
  font-size: 2.2rem;
}

@media screen and (max-width: 520px) {
  :is(.box-tel, .box-line) {
    padding-top: 40px;
    padding-bottom: 40px;
    width: var(--base_midwidth);
    padding: 25px;
  }

  :is(.box-tel, .box-line) .tit_A {
    font-size: 2.2rem;
    margin: 0 auto 15px;
  }

  :is(.box-tel, .box-line) > p {
    text-align: left;
  }

  .box-tel .link_tel {
    border: 1px solid var(--white);
    padding: 15px 0;
    border-radius: 5px;
  }
  .box-tel .link_tel span {
    font-size: 3rem;
  }

  .box-line .link_line {
    margin: 20px auto 0;
    width: 100%;
    font-size: 2rem;
  }
}
