@charset "UTF-8";
/* =======================================================================
 ●style,cssの上書き+追加 レスポンシブ化する際に必要な箇所のみ編集
======================================================================= */
.key { font-size: 2.8em; padding: 1.2em .6em 1.4622em; color: #f29410; background: url(../images/key_bg.jpg) no-repeat center; box-sizing: border-box; border: 1px solid #c0c0c0; border-radius: 8px; }

.key span { font-size: .5em; margin-bottom: 1.6em; display: block; color: #876157; text-shadow: 2px 2px 5px white, -2px -2px 5px white, -2px 2px 5px white, 2px -2px 5px white; }

.key b { color: #f29410; }

@media only screen and (min-width: 769px) { .nopc { display: none; }
  .access_map { width: 270px; float: left; }
  .access_frame { width: 370px; float: right; background-color: #ebebeb; } }
@media only screen and (max-width: 768px) { * { max-width: 100%; box-sizing: border-box; }
  img { height: auto; }
  iframe { max-width: 100%; }
  .nosp { display: none; }
  .key { font-size: 1.8em; text-align: center; border-radius: 0; border: 0; line-height: 1.2; }
  h3 { position: relative; max-width: none; margin: 0 -5% 20px; padding: 15px 15px 10px 40px; background: #fcf1d6; }
  h3::before { content: ""; position: absolute; top: 50%; left: 3px; width: 23px; height: 12px; transform: translateY(-50%); background: #f29410; }
  body { background-color: #fff; }
  a:link { color: #0000ff; text-decoration: none; }
  .contbox { margin: 0 auto; padding: 0; border: 0; border-radius: 0; }
  #header h1 { width: 100%; white-space: nowrap; overflow: auto; padding: 5px 3% 0; }
  #header #logo-add { height: auto; display: flex; align-items: center; justify-content: space-between; padding: 0 10px; }
  #header #logo-add::after { display: none; }
  #header #logo-add .logo { width: 100%; float: none; display: flex; align-items: center; margin-top: 0; }
  #header #logo-add .logo a { padding: 1em 0; display: block; width: 100%; }
  #contents_wrapper { padding: 0 5%; }
  #main_contents { float: none; }
  #information { border-radius: 16px; }
  #infobox .info { width: 100%; float: none; }
  #infobox .map { width: 270px; float: none; margin: 0 auto; }
  #sub_contents { width: 100%; margin: 30px auto; text-align: center; float: none; }
  ul#sub_nav { height: auto; }
  .bana { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; }
  .bana.w100 { justify-content: center; }
  .bana.w100 a { width: auto; }
  .bana br { display: none; }
  .bana a { width: 48%; }
  #footer { position: relative; padding-bottom: 85px; }
  #footer_nav { padding: 0; background-position: right bottom; }
  #footer_nav ul { display: flex; flex-wrap: wrap; }
  #footer_nav li { float: none; width: 50%; margin: 0; text-align: center; border-right: 1px dotted rgba(255, 255, 255, 0.4); border-bottom: 1px dotted rgba(255, 255, 255, 0.4); }
  #footer_nav .w100 { width: 100%; }
  #footer_nav li a { display: block; padding: 1rem 0; }
  #footer .copyright { padding: 60px 0 0; }
  .menu-item > div { display: flex; flex-wrap: wrap; justify-content: space-between; }
  .menu-item > div::after { display: none; }
  .menu-item .menu { float: none; width: 48%; margin: 0 0 4%; }
  .menu-item2 .menu { float: none; margin: 0 auto 10px; }
  .menu-item2 .menu a:link, .menu-item2 .menu a:visited { margin: 0 auto; }
  .sp_menu2 { display: flex; flex-wrap: wrap; justify-content: space-between; }
  .sp_menu2 .menu { width: 48%; margin: 0 0 4%; }
  .sp_menu2::after { display: none; }
  .menu-item2 .menu a.nolink { margin: 0 auto; }
  .flow { width: 90%; }
  /* :::::::::: excimer :::::::::: */
  	/*.excimer_leadPic02 { 	height: 0; }*/
  .excimer_leadPic02 p { margin: 0; }
  .excimer_leadPic02 p.cutimg { float: none; margin-left: 0; text-align: center; }
  .excimer_leadPic02 p.cutimg02 { float: none; margin-left: 0; text-align: center; }
  /* :::::::::: acne :::::::::: */
  .wds_li { max-width: fit-content; }
  .hsp-pp-img { flex-wrap: wrap; justify-content: center; }
  /* ------------------------------------------------- drawer ---------------------------------------------------- */
  html { overflow-y: scroll; }
  .Drawer { position: fixed; z-index: 11; top: 0; left: 0; width: 100%; height: calc(100% - 85px); }
  .Drawer-backdrop { position: absolute; z-index: -1; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); }
  .Drawer-nav { position: absolute; top: 0; right: 0; height: 100%; width: 80%; background: #f9f9f9; }
  .Nav { overflow: auto; -webkit-overflow-scrolling: touch; }
  .Drawer[aria-expanded] { transition-property: visibility; transition-duration: 0.25s; }
  .Drawer[aria-expanded] .Drawer-backdrop { transition-property: opacity; transition-duration: 0.25s; transition-timing-function: linear; }
  .Drawer[aria-expanded] .Drawer-nav { transition-property: transform; transition-duration: 0.25s; transition-timing-function: ease; }
  /* 開いているとき */
  .Drawer[aria-expanded="true"] { visibility: visible; transition-duration: 0s; }
  .Drawer[aria-expanded="true"] .Drawer-backdrop { opacity: 1; }
  .Drawer[aria-expanded="true"] .Drawer-nav { transform: translateX(0); }
  /* 閉じているとき */
  .Drawer[aria-expanded="false"] { visibility: hidden; }
  .Drawer[aria-expanded="false"] .Drawer-backdrop { opacity: 0; }
  .Drawer[aria-expanded="false"] .Drawer-nav { transform: translateX(100%); }
  .Nav-button { position: absolute; bottom: -85px; right: 0; width: 25%; height: 80px; border: 0; padding: 0; background: #ffeebb; opacity: 0; transition-property: opacity; transition-duration: 0.25s; transition-timing-function: linear; }
  .Nav-button img { width: auto; max-height: 90%; }
  .Drawer[aria-expanded="true"] .Nav-button { opacity: 1; }
  .Nav-button::before { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.1); content: ""; opacity: 0; transition-property: opacity; transition-duration: 0.1s; transition-timing-function: linear; }
  .Nav-list { margin: 80px 0 0; padding: 0 10px; list-style-type: none; }
  .Nav-item { margin: 0; border-width: 0 0 1px; border-style: solid; border-color: #bd9f74; }
  .Nav-item.bdb0 { border-bottom: 0; }
  .Nav-item:first-child { border-top-width: 1px; }
  .Nav-link { display: block; position: relative; padding: 1rem; line-height: 1.2; text-decoration: none; color: #6d3f33; }
  a.Nav-link { color: #6d3f33; }
  a.Nav-link:after { content: ""; position: absolute; right: 10px; width: 6px; height: 6px; border-width: 1px 1px 0 0; border-style: solid; border-color: #f29410; transform: rotate(45deg); top: calc(50% - 4px); }
  span.Nav-link { text-align: center; padding: 1.2rem 0; }
  .Nav-link:before { color: #f9f15c; }
  .Nav-listBoxIn { position: absolute; width: 100%; background: #fff; height: 80px; top: -80px; left: 0; border-right: 1px solid rgba(0, 0, 0, 0.1); }
  .Nav-listBoxIn:after { content: ""; display: block; position: absolute; height: 1px; bottom: 0; left: 0; width: 100%; background: rgba(0, 0, 0, 0.1); }
  .Nav-listBoxIn a { display: flex; width: 100%; height: 100%; padding: 10px; align-items: center; text-align: center; }
  .Nav-listBox { position: relative; background: #f9f9f9; }
  .sub_menu { max-width: none; margin-right: -10px; margin-left: -10px; padding: 10px 15px; text-align: center; background: #f9d397; }
  .sub_menu > a { display: inline-block; }
  .sub_menu > a img { width: 50%; margin: 0 auto 10px; }
  .Nav-listIn { margin: 0 auto; list-style: none; border-radius: 4px; text-align: left; background: #f9f9f9; }
  .Nav-listIn .Nav-link { position: relative; padding: 1rem 1rem 1rem 50px; color: #6d3f33; background-color: #fdf3d9; background-position: left 10px center; background-repeat: no-repeat; background-size: 30px; }
  .Nav-listIn .s_general a { background-image: url(../images/sp_m_general.png); }
  .Nav-listIn .s_pediatrics a { background-image: url(../images/sp_m_pediatrics.png); }
  .Nav-listIn .s_allergy a { background-image: url(../images/sp_m_allergy.png); }
  .Nav-listIn .s_ipl a { background-image: url(../images/sp_m_ipl.png); }
  .Nav-listIn .s_peeling a { background-image: url(../images/sp_m_peeling.png); }
  .Nav-listIn .s_aga a { background-image: url(../images/sp_m_aga.png); }
  .Nav-listIn .s_hospital-preparation a { background-image: url(../images/sp_m_hospital-preparation.png); }
  .Nav-listIn .Nav-link:before { content: ""; width: 50px; height: 48px; position: absolute; left: 0; top: 0; z-index: 1; background-position: center; background-repeat: no-repeat; background-size: 35px; }
  .Nav-listIn .Nav-item:first-of-type { border-top: 0; }
  .Nav-listIn .Nav-item:last-of-type { border-bottom: 0; }
  .Nav-bn { margin-right: -10px; margin-left: -10px; max-width: none; border: 0; background: #e8e8dc; padding: 1em; }
  .Nav-bn a { display: block; padding: 10px; border-radius: 4px; background: #fff; }
  .Nav-bn .bn-reserve { padding: 10px 5px; margin-top: 1em; background: #fff; text-align: center; }
  .bn { text-align: center; padding: 1rem 0; }
  .bn a { display: inline-block; }
  /* ------------------ gallery --------------------*/
  .gallery { width: 300px; max-width: 100%; margin: 0 auto; }
  .gallery * { max-width: 100%; }
  .gallery img { height: auto !important; }
  .gv_gallery { max-width: 100%; height: auto !important; }
  .gv_galleryWrap { max-width: 100%; height: auto !important; }
  .gv_panelWrap { position: static !important; max-width: 100%; height: auto !important; padding: 0 !important; }
  .gv_infobar { top: 0; }
  .gv_panel { position: static !important; max-width: 100%; max-height: 370px; }
  .gv_panel img { max-width: 300px; height: auto !important; left: 50% !important; transform: translateX(-50%); }
  .gv_filmstripWrap { max-width: 100%; }
  .gv_filmstrip { display: flex; }
  .gv_panelNavPrev, .gv_panelNavNext { top: calc((100% - 160px) / 2) !important; }
  .access_map { text-align: center; margin-bottom: 1.5em; }
  .sp_footer { position: fixed; width: 100%; bottom: 0; left: 0; background: #ffeebb; border-top: 5px solid #f5bc6d; height: 85px; }
  .sp_footer ul { display: flex; flex-wrap: wrap; margin: 0; padding: 0; height: 100%; }
  .sp_footer li { width: 25%; height: 100%; margin: 0; text-align: center; list-style: none; border-right: 1px solid #f5bc6d; }
  .sp_footer li:last-of-type { border-right: 0; }
  .sp_footer a { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; }
  .sp_footer button { justify-content: center; width: 100%; height: 100%; border: 0; padding: 0; background: transparent; }
  .sp_footer a img, .sp_footer button img { width: auto; max-height: 90%; } }

/*# sourceMappingURL=responsive.css.map */
