@charset "utf-8";
/* -------------------------------------------
  Auther: design studio tom'sOne / Tommy Tsutsui / https://toms1.net/
  Issued in: 05/Jun/2024 / Last modefied: 05/Jun/2024
------------------------------------------- */

/* -------------------------------------------
  Reset
------------------------------------------- */
html{font-size:62.5%}body,a,address,header,html,iframe,nav{padding:0;margin:0}address,header,html,iframe,nav{border:0;outline:0}abbr,article,aside,audio,b,canvas,cite,code,del,details,dfn,em,fieldset,figcaption,figure,form,hgroup,i,img,ins,kbd,label,legend,mark,menu,object,pblockquote,pre,q,samp,span,strong,sub,summary,sup,time,var,video{background:0 0;margin:0;padding:0;border:0;outline:0}footer,h1,h2,h3,h4,h5,h6,p,section,small{border:0;outline:0}address,article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a img,figure{vertical-align:top}abbr[title],dfn[title]{cursor:help}input,select{vertical-align:middle}noscript{margin:0}

/* Desktop Hide Items */
.spTopCalender { display: none}

/* -------------------------------------------
  Fonts
------------------------------------------- */
body  {
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", HelveticaNeue, "source-han-sans-japanese", "Segoe UI", "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif}

.notoSans, .NS400, .NS500, .NS600, .NS700, #globalNav, #footAddress, #ANReserve, #ANFIP, .BreadcrumbList, #topHeadCopy, .ONItem,
.LBBox, .LBBlack, .THIJP, .TNItem, .topCal, .topST, .TBCopy, .BBTit, .slick-next:before, .slick-prev:before, #fixReserveBT, .BIIKind,
.pageTitle, .pageST, .NTLST, .OSOItem, .GMNLink, .TAniKind, #WCBDList th, #WCBDList td, #MShipDetail th, #MShipDetail td, .MDPT,
.MDSCat, .MDSLink, .MDCST, .CHLItem, .medInfoCopy, .MDiseaseName, .MDDKind, .MDDExp, .MDListST, .MDListCopy, .MDWICopy, .OSOST,
.MDLBlessCopy, .MDNoICopy, .SFlowProcess, .SFlowGuide, .GMNIName, .GMNINameW, .SPMKind, .SPMKindW, #HDMName, .HDMTA, .staffKind,
.staffName, .staffMessage, .SISpecialized, .SIBio, .ALData, .NLTitle, .newsTitle, .newsBody, .symptomDetail, .possibleDiseases,
.CSNItem, .keyItem, #paginationList li, #newsIndNavi, #blogIndNavi {
  font-family: "Noto Sans JP", sans-serif; font-optical-sizing: auto; font-style: normal}

.NS400, .ONItem, #ANReserve, #fixReserveBT, .BreadcrumbList, #footAddress, .BIIKind, #ANFIP, .TBCopy, .OSOItem, .TAniKind,
.MDSLink, .MDDExp, .MDListCopy, .MDWICopy, .MDWICopy02, .MDLBlessCopy, .MDNoICopy, .SFlowGuide, .HDMTA, .ALCopy,
.newsBody p, .newsBody li, .CSNItem, .keyItem, .symDD, .PDDD, #paginationList li { font-weight: 400}

.win .NS400, .win #ANReserve, .win #fixReserveBT, .win #ANFIP, .BBTit, .win .TBCopy, .win .OSOItem, .win .TAniKind,
.win .MDSLink, .win .MDDExp, .win .MDListCopy, .win .MDWICopy, .win .MDWICopy02, .win .MDLBlessCopy, .win .MDNoICopy,
.win .SFlowGuide, .win .HDMTA, .win .ALCopy, .win .newsBody p, .win .newsBody li, .win .symDD, .win .PDDD, .win #paginationList li {
  font-weight: 500}


.NS500, .LBBox, .LBBlack, .THIJP, .TNItem, .topCal, #WCBDList th, #WCBDList td, #MShipDetail th, #MShipDetail td, .OSOST, .MDSCat,
.CHLItem, .medInfoCopy, .MDDKind, .SFlowProcess, .GMNLink, .GMNIName, .GMNINameW, .SPMKind, .SPMKindW, #HDMName, .staffKind, .staffName,
.ALTitle, .NLTitle, .newsBody h2, .newsBody h3, .newsBody b, .symDT, .PDDT, #newsIndNavi, #blogIndNavi { font-weight: 500}

.NS600, #globalNav, #topHeadCopy, .topST, .pageTitle, .pageST, .MDPT, .MDCST, .slick-next:before, .slick-prev:before,
.MDiseaseName, .MDListST, .SPSVCC, .newsTitle, .newsBody h4, .newsBody h5 { font-weight: 600}

.NS700, .win .MDPT { font-weight: 700}

.figtree, .FI400, .FI500, .FI600, .FI700, .FI800, #THEnCopy, .THIST, .PTEn, .PSTEn, .NTLNum, .MDHead, .MDPTEn, .SKindEn, .SNameEn {
  font-family: "Figtree", sans-serif; font-optical-sizing: auto; font-style: normal}

.FI400 { font-weight: 400}
.FI500, .THIST, #WCBDList th, #WCBDList td, .SNameEn { font-weight: 500}
.FI600, #THEnCopy, .PSTEn, .NTLNum, .MDHead, .MDPTEn, .SKindEn { font-weight: 600}
.win .FI600, .win #THEnCopy, .win .PSTEn, .win .NTLNum, .win .MDHead, .win .MDPTEn, .win .SKindEn { font-weight: 700}
.FI700, .PTEn { font-weight: 700}
.FI800 { font-weight: 800}

.barlow, .bal400, .bal500, .bal600, .bal700, .bal800, #ANTel, #footTel, #copyright,
.ORTNum, .TNTime, .openTime, .TSEN, .ALTime, .CSBST, .NLTime { font-family: "Barlow", sans-serif; font-style: normal}

.bal400, #ANTel, #copyright, .ORTNum, .TNTime, .NLTime { font-weight: 400}
.win .bal400, .win #ANTel, .win #copyright, .win .ORTNum, .win .TNTime, .win .NLTime { font-weight: 500}

.bal500, #footTel, .TSEN, .ALTime, .CSBST { font-weight: 500}
.bal600, .openTime { font-weight: 600}
.bal700 { font-weight: 700}
.bal800 { font-weight: 800}


/* -------------------------------------------
  Common
------------------------------------------- */
@font-face { font-family: "Yu Gothic M"; src: local("Yu Gothic Medium")}
@font-face { font-family: "Yu Gothic M"; src: local("Yu Gothic Bold"); font-weight: bold}

* {min-height: 0vw}

body {
  position: relative; color: #333; background: #fff; -webkit-text-size-adjust: 100%; font-size: 1rem;
  line-height: 1; width: 100%; min-width: 1120px; height: 100%; z-index: 1}

.lazyload { opacity: 0} .lazyloaded { opacity: 1; -webkit-transition: all 0.5s; transition: all 0.5s}

.mag20 { margin-top: 20px !important} .mag50 { margin-top: 50px !important}
.magLM02 { margin-left: -.25em !important} .magLM03 { margin-left: -.35em !important}
.pad01 { padding-top: 1em !important}

.ls0 { letter-spacing: 0 !important} .ls03 { letter-spacing: .03em !important}
.ls05 { letter-spacing: .05em !important} .ls10 { letter-spacing: .1em !important} .ls12 { letter-spacing: .125em !important}
.ls15 { letter-spacing: .15em !important} .ls20 { letter-spacing: .2em !important} .ls30 { letter-spacing: .3em !important}
.ls50 { letter-spacing: .5em !important} .ls100 { letter-spacing: 1em !important} .ls110 { letter-spacing: 1.1em !important}

.lsM01 { letter-spacing: -.01em !important} .lsM02 { letter-spacing: -.025em !important}
.lsM05 { letter-spacing: -.05em !important} .lsM07 { letter-spacing: -.075em !important}
.lsM10 { letter-spacing: -.1em !important} .lsM15 { letter-spacing: -.15em !important}
.lsM20 { letter-spacing: -.2em !important} .lsM25 { letter-spacing: -.25em !important}
.lsM30 { letter-spacing: -.3em !important} .lsM50 { letter-spacing: -.5em !important}

.lsW03 { margin: 0 3px !important}
.lsN01 { margin: 0 -1px !important} .lsN02 { margin: 0 -2px !important}
.lsEM02 { margin: 0 -.2em !important} .lsEM03 { margin: 0 -.35em !important}

.DBlock { display: block !important}
.InBlock { display: inline-block !important}

.fLeft { float: left; } .fRight { float: right}

figure img { width: 100% !important; height: auto; vertical-align: top}

.imRud50 { border-radius: 50%}

/* Common Image */
.homeLink, .ANTelSign, .ANResSign, .AMFIPSign, #botLogo, .petInsurance, .FTElSign, .creditCard, .instaLink,
.ORTSign, .ORInstaLogo, #ORLogo {
 background-image: url(../images/common/common.svg); background-repeat: no-repeat; background-size: 306px 332px}

/* Flex Container
------------------------------------------- */
.flexC, #headNav, .ANList, #globalNav, .MDDetail, .MDwithImage, .SIHead, .ALItem, .NLItem {
  display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between;
  -webkit-flex-flow: row wrap; flex-flow: row wrap}

/* Common Header
------------------------------------------- */
#globalHeader {
  position: absolute; top: 0; left: 0; background: transparent;
  width: 100%; height: 118px; margin: 0; z-index: 500; -webkit-transition: all .6s; transition: all .6s}

#globalHeader:hover { background: rgba(255,255,255,.7)}

.GHInner { width: calc(100% - 10vw); height: 66px; margin: 0 auto; position: relative}

#homeLogo { position: absolute; top: 28px; left: 0; width: 282px; margin: 0}

.homeLink { background-position: 0 0; width: 282px; height: 56px; display: block; position: relative; opacity: 1}
.homeLink:hover { opacity: .7}

.fixed #homeLogo { position: fixed; top: 12px; left: 5vw; width: 170px; height: 34px}
.fixed .homeLink { background-size: 184px 200px; width: 170px; height: 34px}

#headNav {
  position: absolute; top: 22px; right: 5vw; -webkit-flex-flow: column; flex-flow: column; align-items: flex-end;
  width: 52%; min-width: 600px; max-width: 860px; height: 66px}

/* Action nav */
#actionNav { width: 500px}

.ANList { margin: 0; padding: 0}

.ANLink { margin: 0; padding: 0; display: block}

.ANItem { height: 30px; display: block}

#ANTel { font-size: 2.5rem; letter-spacing: .05em; width: 186px; padding-top: 4px}
#ANReserve, #ANFIP { font-size: 1.8rem; text-align: right; letter-spacing: .06em; width: 116px}
#ANFIP { width: 110px}

.ANLink { color: #333; text-decoration: none; position: relative}
#ANTel .ANLink { padding-left: 24px}
#ANReserve .ANLink, #ANFIP .ANLink { padding-top: 6px}

.ANLink:hover { color: #2299a7; -webkit-transform: translateY(-2px); transform: translateY(-2px)}

.ANTelSign, .ANResSign, .AMFIPSign { position: absolute; left: 0; display: block}

.ANTelSign { top: 3px; background-position: -180px -140px; width: 20px; height: 20px}
.ANLink:hover .ANTelSign { -webkit-transform: translateX(4px) rotate(20deg); transform: translateX(4px) rotate(20deg)}

.ANResSign { top: 0; background-position: -220px -140px; width: 30px; height: 30px}

.AMFIPSign { top: 1px; background-position: -270px -140px; width: 31px; height: 28px}

.ANLink:hover .ANResSign, .ANLink:hover .AMFIPSign { transform: rotate(7deg)}

/* Global nav */
#GNav { position: absolute; bottom: 0; right: 0; width: 100%}

#globalNav { font-size: 1.5rem; margin: 0; padding: 0}

.GNON { letter-spacing: .05em; margin: 0; white-space: nowrap; display: block; position: relative}

#globalNav a { color: #555; text-decoration: none; padding: 7px 0}
#globalNav a:hover { color: #2299a7}

#globalNav .current { position: relative}
#globalNav .current, #globalNav .current:hover { color: #f55e00}

.current:after {
  content: ''; position: absolute; bottom: -2px; left: 50%; width: 0; height: 0; margin-left: -4px; display: block;
  border-style: solid; border-width: 5px 4px 0 4px; border-color: #f57e00 transparent transparent transparent}

#globalHeader.fixed {
 position: fixed; top: 0; left: 0; background: rgba(255,255,255,.95);
 min-height: 0; height: 60px; overflow: visible; z-index: 9999}

.fixed #globalNav { margin-top: 0}

#GNLine {
  position: absolute; bottom: -8px; height: 2px; background-color:#f57e33;
  -webkit-transition: all .2s ease-in-out; transition: all .2s ease-in-out; z-index: 9960}

/* Overlay Navi */
.menu-trigger { position: absolute; top: 24px; right: 24px; width: 66px; height: 66px}
.fixed .menu-trigger { top: 10px; right: 10px}

#trigger-overlay { position: fixed; z-index: 9999}

#trigger-overlay::before, #trigger-overlay::after {
  content: ''; position: absolute; top: 0; right: 0; width: 66px; height: 66px; display: block}
#trigger-overlay::before { background: rgba(0,108,130,.85); z-index: -2}
#trigger-overlay::after { background: rgba(0, 170, 180, 0.9); -webkit-transform: scale(0); transform: scale(0); z-index: -1}

#trigger-overlay:hover::after, #trigger-overlay.active::after { -webkit-transform: scale(1); transform: scale(1)}
#trigger-overlay:hover.active::after { -webkit-transform: scale(0); transform: scale(0)}

.menu-trigger, .menu-trigger span { display: inline-block; box-sizing: border-box}

.menu-trigger, .menu-trigger .HMBar, .menu-trigger:after {
  -webkit-transition: all .4s cubic-bezier(.075, .82, .165, 1); transition: all .4s cubic-bezier(.075, .82, .165, 1)}

.HMBox { margin: 18px 0 0 15px}

.menu-trigger .HMBar {
  background: #f0f0f0; width: 36px; height: 3px; display: block;  position: relative;
  -webkit-transition: all .7s cubic-bezier(.19, 1, .22, 1); transition: all .7s cubic-bezier(.19, 1, .22, 1);
  -webkit-transform-origin: right bottom; transform-origin: right bottom}

.menu-trigger .HMBar:nth-child(1) { -webkit-transition-delay: 150ms; transition-delay: 150ms}
.menu-trigger .HMBar:nth-child(2) { width: 22px; top: 10px; -webkit-transition-delay: .08s; transition-delay: .08s}

.menu-trigger.active .HMBar { background: #fff53e}

.menu-trigger.active .HMBar:nth-child(1) {
  top: -1px; left: -5px; width: 38px; -webkit-transform: rotate(315deg); transform: rotate(315deg)}

.menu-trigger.active .HMBar:nth-child(2) {
  top: 23px; left: -7px; width: 38px; -webkit-transform: rotate(-315deg); transform: rotate(-315deg)}

.HMName {
  position: absolute; top: 41px; left: 0; color: #fff; font-size: 1.1rem; font-style: normal; text-align: center;
  letter-spacing: .08em; text-indent: .05em; width: 100%; transform: none; opacity: 1}
.menu-trigger.active .HMName { -webkit-transform: translate(0,100px); transform: translate(0,100px); opacity: 0}

/* Overlay */
.overlay {
  position: fixed; top: 0; right: 0; background: rgba(60,60,60,.95);
  width: 100%; height: 100vh; overflow: auto; z-index: 9980;
  -webkit-backdrop-filter: saturate(180%) blur(10px); backdrop-filter: saturate(180%) blur(10px)}

/* Overlay Effects */
.overlay-slidedown {
  visibility: hidden; -webkit-transform: translateX(110%) skewX(10deg); transform: translateX(110%) skewX(10deg);
  -webkit-transition: -webkit-transform .4s ease-in-out, visibility 0s .4s;
  transition: transform .4s ease-in-out, visibility 0s .4s}

.overlay-slidedown.open {
  visibility: visible; -webkit-transform: translateX(0%) skewX(0deg); transform: translateX(0%) skewX(0deg);
  -webkit-transition: -webkit-transform .4s ease-in-out; transition: transform .4s ease-in-out}

/* Overlay Menu */
#ORContainer { width: 90%; max-width: 800px; margin: 0 auto; padding: 5vw}

.ORNav { width: 340px; position: relative}

.ORNLeft { padding-bottom: 250px}

.overlayNav { margin: 0; padding: 0}

.ORAbbr { color: #aeaeae; font-size: 1.3rem; letter-spacing: .15em; margin: 0}

.ONItem { font-size: 1.6rem; letter-spacing: .12em; margin: 20px 0}
.ONItem:last-of-type { margin-bottom: 1.1em}

.ONSec { margin: 0; padding: 0 0 0 18px}

.ONCI { margin: 5px 0 0}

.ONKind { color: #f7dd99; padding: 0 15px 10px .6em; display: inline-block; position: relative}

.ONKind::after { content: ''; position: absolute; top: 50%; right: 0; background: #f7dd99; margin-top: -8px;
  width: 8px; height: calc(8px / 2 * tan(60deg)); display: inline-block; opacity: .65; clip-path: polygon(0 0, 100% 0, 50% 100%)}

.ONItem a {
  background: inherit; color: #e5e5e5; text-decoration: none; padding: .4em .6em;
  position: relative; display: inline-block; cursor: pointer; overflow: hidden}
.ONItem a:hover { color: #fff}

.ONItem a::before {
  content: ''; position: absolute; top: 0; left: auto; right: 0; z-index: -1; background: rgb(0,150,160);
  width: 0; height: 100%; border-radius: 3px; display: block}
.ONItem a:hover::before { left: 0; right: auto; width: 100%}

.ORInfo { position: absolute; bottom: 18px; left: 0; height: 175px}

#ORLogo { background-position: 0 -240px; width: 280px; height: 50px; margin: 0; display: block}

#ORTel { font-size: 3rem; margin: 10px 0 0}

.ORTNum {
  color: #ccc; text-decoration: none; letter-spacing: .075em; display: inline-block;
  margin: 12px 0 0; padding-left: 28px; position: relative; -webkit-transform: none; transform: none}
.ORTNum:hover { color: #b2e9f0; -webkit-transform: translate(1px, -1px); transform: translate(1px, -1px)}

.FTElSign {
  position: absolute; top: 12px; left: 0; display: block;
  background-position: -180px -140px; width: 20px; height: 20px; -webkit-transform: none; transform: none}

.FTelNum:hover .FTElSign { -webkit-transform: rotate(12deg) translate(3px,-1px); transform: rotate(12deg) translate(3px,-1px)}


.ORTSign { position: absolute; top: 8px; left: 0; background-position: -180px -140px; width: 20px; height: 20px; display: block}
.ORTNum:hover .ORTSign { -webkit-transform: rotate(20deg); transform: rotate(20deg)}

#ORInstaLink { margin: 30px 0 0}
.ORInstaLogo { background-position: 0 -300px; width: 142px; height: 32px; margin: 0; opacity: .8; display: block}
.ORInstaLogo:hover {
  -webkit-transform: translate3d(4px,-4px,0) rotate(-2deg); transform: translate3d(4px,-4px,0) rotate(-2deg); opacity:1}

/* -------------------------------------------
 Footer
------------------------------------------- */
footer { background: #eaeaea; padding: 0 5%; position: relative; z-index: 1}

#footInner { max-width: 1600px; height: 580px; margin: 0 auto; padding-top: 90px}

/* Bottom ID */
#footID { width: 420px; position: relative}

#bottomID { height: 400px; position: relative}

#botLogo { background-position: 0 -180px; width: 306px; height: 56px; margin: 0}

#footAddress { margin-top: 48px}

#FCompAdd, .botOpeningHours { font-size: 1.5rem; font-style: normal; letter-spacing: .06em; margin: 0}

.botOpeningHours { margin-top: 15px}

#footTel {
  font-size: 3.6rem; font-style: normal; letter-spacing: .075em; display: inline-block;
  margin: 12px 0 0; padding-left: 28px; position: relative; -webkit-transform: none; transform: none}
#footTel:hover { -webkit-transform: translate(1px, -1px); transform: translate(1px, -1px)}

.FTelNum { color: #444; text-decoration: none; display: block}
.FTelNum:hover { color: #1e8eb7}

.FTElSign {
  position: absolute; top: 10px; left: 0; display: block;
  background-position: -180px -140px; width: 20px; height: 20px; -webkit-transform: none; transform: none}

.FTelNum:hover .FTElSign { -webkit-transform: rotate(12deg) translate(3px,-1px); transform: rotate(12deg) translate(3px,-1px)}

.botInfo { position: absolute; bottom: 0; left: 0; width: 420px; height: 140px}

.botInfoItem { background: #fff; text-align: center; width: 200px; height: 140px}

.BIIKind { font-size: 1.4rem; margin: 20px 0 0}

.petInsurance { background-position: 0 -60px; width: 130px; height: 76px; margin: 12px auto 0; display: block}
.creditCard { background-position: -150px -60px; width: 148px; height: 72px; margin: 14px auto 0; display: block}

.botInsta { width: 100%; margin-top: 30px}

.instaLink { background-position: 0 -140px; width: 168px; height: 38px; margin: 0 auto; display: block}
.instaLink:hover { transform: translate(2px,-1px); opacity: .7}

#copyright {
  position: absolute; bottom: 50px; left: 0;
  font-size: 1.5rem; text-align: center; letter-spacing: .08em; width: 100%; margin: 0; display: block}

/* Bottom Map */
#botmap {
  position: absolute; top: 40px; right: 40px; width: 50vw}

.GMapWrapp { width: 100%; padding: 1px; border: 1px solid #bbb}

#GMap { width: calc(100% - 2px); height: 448px; border: 1px solid #fff}

.AccessBT { margin: 20px 0 0}

/* -------------------------------------------
  Fixed Navi
------------------------------------------- */
#sideFixBT { position: fixed; bottom: 25vw; right: 0; z-index: 999}

#fixReserveBT {
  font-size: 2.6rem; -webkit-font-feature-settings: 'pkna'; font-feature-settings: 'pkna';
  -webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; font-feature-settings: "palt";
  text-orientation: upright; text-align: center; letter-spacing: .06em; margin: 0; white-space: nowrap;
  margin: 0; border-radius: 7px 0 0 7px; border: 1px solid #fff; border-right: none; position: relative; z-index: 1}

.fixedBTLink { color: #fff; text-decoration: none; padding: 15px calc(2.5vw - 14px); display: block}

.fixedBTLink::before, .fixedBTLink::after {
  content: ''; position: absolute; top: 0; height: 100%; border-radius: 7px 0 0 7px; display: block}
.fixedBTLink::before { right: 0; background: rgba(0,108,130,.85); width: 100%; z-index: -2}

.fixedBTLink::after { left: 0; width: 0; z-index: -1}
.fixedBTLink::after { left: auto; right: 0; background: rgba(0,180,190,.9)}
.fixedBTLink:hover::after { left: 0; right: auto; width: 100%}

.is-hidden { visibility: hidden; opacity: 0}

/* -------------------------------------------
  Return Button
------------------------------------------- */
#returnBT { position: fixed; bottom: 0; right: 0; margin: 0; z-index: 9999}

#retTop { margin: 0; position: relative}

#retTop:before, #retTop:after {
 content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 100%; display: block;
 z-index: -1; -webkit-transform-origin: center; transform-origin: center}
#retTop:before { background: rgba(68,68,68,.8)}
#retTop:after { background: rgba(0, 170, 180, 0.9); -webkit-transform: scale(0); transform: scale(0)}
#retTop:hover:after { -webkit-transform: scale(1); transform: scale(1)}

#retTop a { color: #fff; width: 90px; height: 70px; margin: 0; text-indent: -9999px; position: relative}

#retTop a:before {
 content: 'page top'; position: absolute; bottom: 23px; left: 0; display: block; cursor: pointer; z-index: 1000;
 color: #fff; font-size: 12px; text-align: center; text-indent: .089em; letter-spacing: .08em; width: 100%}
#retTop a:after {
 content: ''; position: absolute; top: 23px; left: 50%; cursor: pointer;
 width: 6px; height: 6px; border-top: 2px solid #fff; border-right: 2px solid #fff; margin-left: -4px;
 -webkit-transform: rotate(-45deg); transform: rotate(-45deg)}
#retTop a:hover:after { top: 20px}

/* -------------------------------------------
 Link Button
------------------------------------------- */
.LBBox, .LBBlack {
  color: #fff; font-size: 1.5rem; text-decoration: none; display: inline-block;
  z-index: 1; overflow: hidden; cursor: pointer; position: relative}
.LBBlack { font-size: 1.7rem; letter-spacing: .06em}

.LBB01 { padding: 17px 65px 17px 30px}
.LBB02 {  min-width: 300px; padding: 17px 30px 17px 30px}
.TNLBB { padding: 12px 65px 12px 30px}
.DBB01 {  min-width: 200px; padding: 17px 48px 17px 30px}
.DBB01:has(.LBLabel){
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 48px 14px 30px;
}

.win .LBB01 { padding: 16px 65px 17px 30px}
.win .LBB02 { padding: 16px 30px 17px 30px}
.win .TNLBB { padding: 11px 65px 13px 30px}

.LBBox::before, .LBBox::after, .LBBlack::before, .LBBlack::after {
  content: ''; position: absolute; top: 0; height: 100%; display: block}
.LBBox::before, .LBBlack::before { left: 0; background: #17798e; width: 100%; z-index: -2}
.LBBlack::before { background: #777}
.LBBox::after, .LBBlack::after { left: auto; right: 0; background: #00a9b2; width: 0; z-index: -1}
.LBBox:hover::after, .LBBlack:hover::after { left: 0; right: auto; width: 100%}

.LBBoxGray { padding: 12px 55px 12px 25px;line-height: 1.8}
.LBBoxGray::before { background: #666}
.LBBoxGray .TNLSign::before,.LBBoxGray .TNLSign::after{
  background: #666;
}

#TNLBNews::before, #TNLBNews .TNLSign::before, #TNLBNews .TNLSign::after { background: #69a53e}
#TNKBColumn::before, #TNKBColumn .TNLSign::before, #TNKBColumn .TNLSign::after { background: #f9851e}

#TNLBCal::before { background: #666}

.LBCenterBT { text-align: center; margin: 25px 0 0}

.LSign01, .TNLSign, .BBLSign, .graySign {
  position: absolute; top: 50%; right: 30px;
  background: #fff; width: 20px; height: 20px; margin-top: -10px; border-radius: 50%; display: block}

.TNLSign { width: 18px; height: 18px; margin-top: -9px}

.TBSign, .BBLSign { position: absolute; background: #fff; width: 30px; height: 30px; border-radius: 50%; display: block}
.TBSign { bottom: 25px; left: 50%; margin-left: -15px}
.BBLSign { top: 202px; right: 18px}

.LSign01::before, .LSign01::after, .TNLSign::before, .TNLSign::after, .TBSign::before, .TBSign::after,
.BBLSign::before, .BBLSign::after {
  content: ''; position: absolute; top: 50%; background: #17798e; height: 2px}
.LSign01::before { left: 4px; width: 12px; margin-top: -1px}
.LSign01::after, .TBSign::after, .BBLSign::after {
  right: 5px; width: 3px; margin-top: -3px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}
.TBSign::before, .BBLSign::before { left: 9px; width: 12px} .TBSign::after, .BBLSign::after { right: 10px; margin-top: -2px}
.LSign02{
  position: absolute; top: 50%; right: 20px;margin-top: -10px; display: block;
  height: 19px;
  width: 18px;
  background: url(../images/common/icon_download.svg) center center / contain no-repeat;
}
.LBBox:hover .LSign02{
  transform: translateY(2px);
  opacity: .8;
}
.LSign03{
  position: absolute; top: 50%; right: 20px;margin-top: -8px; display: block;
  height: 16px;
  width: 16px;
  background: url(../images/common/ico_arrow_down.svg) center center / contain no-repeat;
}
.LBBox:hover .LSign03{
  transform: translateY(2px);
  opacity: .8;
}

.LBBlack .TNLSign::before, .LBBlack .TNLSign::after,
#TNLBCal .TNLSign::before, #TNLBCal .TNLSign::after, .TBSign::before, .TBSign::after, .BBLSign::before, .BBLSign::after {
  background: #888}

.LBBlack:hover .TNLSign::before, .LBBlack:hover .TNLSign::after,
#TNLBCal:hover .TNLSign::before, #TNLBCal:hover .TNLSign::after { background: #2e99bb}

.TNLSign::before { left: 4px; width: 10px}
.TNLSign::after { right: 5px; width: 3px; margin-top: -2px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}

.graySign { background: #b5b5b5; width: 22px; height: 22px; margin-top: -11px}
.GMNLink:hover .graySign, .SPMLink:hover .graySign { background: #00a9b2; width: 26px; height: 26px; margin: -13px -2px 0 0}

.graySign::before, .graySign::after { content: ''; position: absolute; background: #fff; height: 2px}
.graySign::before { top: 50%; left: 6px; width: 10px; margin-top: -1px}
.graySign::after { top: 8px; right: 8px; width: 3px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}
.GMNLink:hover .graySign::before, .SPMLink:hover .graySign::before { left: 8px}
.GMNLink:hover .graySign::after, .SPMLink:hover .graySign::after { top: 10px; right: 10px}

/* Link Sign */
.LBBox:hover .LSign01 { width: 24px; height: 24px; -webkit-transform: translate(2px,-2px); transform: translate(2px,-2px); opacity: .8}
.LBBox:hover .LSign01::before, .TNLBB:hover .TNLSign::before, .LBBlack:hover .TNLSign::before { left: 6px}
.LBBox:hover .LSign01::after, .TNLBB:hover .TNLSign::after, .LBBlack:hover .TNLSign::after  { right: 7px}

.TNLBB:hover .TNLSign, .LBBlack:hover .TNLSign {
  width: 22px; height: 22px; -webkit-transform: translate(2px,-2px); transform: translate(2px,-2px); opacity: .8}

.BBNLink:hover .BBLSign { background: #d5f0f2}
.BBNLink:hover .BBLSign::before, .BBNLink:hover .BBLSign::after { background: #17798e}

#TNLBNews:hover .TNLSign::before, #TNLBNews:hover .TNLSign::after, #TNKBColumn:hover .TNLSign::before,
#TNKBColumn:hover .TNLSign::after { background: rgb(0,170,180)}

.TBLink:hover .TBSign { bottom: 23px; width: 34px; height: 34px; margin-left: -17px}
.BBNLink:hover .BBLSign { top: 200px; right: 16px; width: 34px; height: 34px}
.TBLink:hover .TBSign::before, .BBNLink:hover .BBLSign::before { left: 11px}
.TBLink:hover .TBSign::after, .BBNLink:hover .BBLSign::after { right: 12px}

.OSOSign, .OSOSign::after, .fivePIsign, .fivePIsign::after, .NLSign, .NLSign::after {
  position: absolute; background: #fff; height: 1px; display: block}
.OSOSign, .NLSign { top: 50%; right: 26px; width: 12px; margin-top: 1px}
.fivePIsign { bottom: 54px; left: 50%; width: 18px; margin-left: -9px}

.MDSLSign, .MDSLSign::after, .CSNSign, .CSNSign::after, .NLSign, .NLSign::after {
  position: absolute; background: #666; height: 1px; display: block}
.MDSLSign, .CSNSign { top: 50%; right: 10px; width: 12px; margin-top: 1px}

.OSOSign::after, .fivePIsign::after, .MDSLSign::after, .CSNSign::after, .NLSign::after {
  content: ''; top: -2px; right: 1px; width: 4px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}

.NLSign, .NLSign::after { background: #808080; height: 2px;}
.NLSign { width: 20px} .NLSign::after { width: 5px}

.OSOLink:hover .OSOSign { right: 23px}
.fivePILink:hover .fivePIsign { margin-left: -5px}
.MDSLink:hover .MDSLSign, .CSNLink:hover .CSNSign { right: 5px}
.NLLink:hover .NLSign { right: 20px}


/* -------------------------------------------
 Main Container
------------------------------------------- */
/* Container
------------------------------------------- */
#stage { background: transparent; position: relative; overflow: hidden}

.pageContents { padding-top: 140px}

#pageHead, #pageHead02 { max-width: 1600px; margin: 50px auto 0; padding-left: 5vw; position: relative}
#pageHead02 { justify-content: flex-end}

.officialHead, #newsHead { max-width: 1340px; margin: 0 auto; padding: 50px 5vw 0}

.officialWrapp { max-width: 1340px; margin: 0 auto; padding: 0 5vw}

.pageWrapp { max-width: 1340px; margin: 0 auto; padding: 70px 5vw 80px}

.innerWrapp { max-width: 1080px; margin: 0 auto; padding: 70px 5vw}

.minWrapp { max-width: 1080px; margin: 0 auto; padding: 60px 5vw 0}

.pageSec { max-width: calc(1340px - 10%); margin: 0 auto; padding: 0 5%}

.BGGray { background: #efefef}
.BGWhite { background: #fff}
.BGMint { background: #e0f0ee}

.numTextList { margin-top: 50px !important}

.MG0 { margin-top: 0 !important} .MG01 { margin-top: 1em !important}
.MG10 { margin-top: 10px !important} .MG20 { margin-top: 20px !important}
.MG30 { margin-top: 30px !important} .MG40 { margin-top: 40px !important}
.MG50 { margin-top: 50px !important} .MG60 { margin-top: 60px !important}
.MG70 { margin-top: 70px !important} .MG80 { margin-top: 80px !important}
.MG90 { margin-top: 90px !important} .MG100 { margin-top: 100px !important}

.patTop0 { padding-top: 0 !important}

.padL0 { padding-left: 0 !important}
.padL30 { padding-left: 30px !important}

.PWBot20 { padding-bottom: 20px !important}
.PWBot50 { padding-bottom: 50px !important} .PWBot60 { padding-bottom: 60px !important}
.PWBot70 { padding-bottom: 70px !important} .PWBot80 { padding-bottom: 80px !important}

.pcNFalse{ display: none; }

/* Breadcrum Navi
------------------------------------------- */
.BreadcrumbList { margin: 0; padding: 0 5vw}

.BCLink, .BCCurrent { float: left; font-size: 1.4rem; letter-spacing: .05em; padding-bottom: 3px}

.BCLink { position: relative}

.LLLink:last-of-type { margin-left: 30px}

.BLSign { color: #666; font-size: 1.5rem; text-align: center; width: 2.5em; margin-top: -3px; display: inline-block}

.BreadcrumbList a {
  color: #333; text-decoration: none; padding-bottom: 3px; border-bottom: 1px solid #7eaebb;
  display: inline-block; position: relative}

.BreadcrumbList a:hover { color: #39b; border: none}


/* Page Eyecatch
------------------------------------------- */
.pageEC {
  background-repeat: no-repeat; width: calc(100% - 480px);
  height: 36vw; min-height: 420px; max-height: 500px; position: relative; z-index: 1}

#aboutEC { background: url(../images/about/eyecatch.webp) no-repeat center / cover}
#staffEC { background: url(../images/about/staff_sample.webp) no-repeat center / cover}
#hospitalEC { background: url(../images/about/hospital_eyecatch.webp) no-repeat center / cover}
#visitorEC { background: url(../images/visitor/eyecatch.webp) no-repeat center / cover}
#puppyKittenEC { background: url(../images/visitor/puppy_kitten/eyecatch.webp) no-repeat center / cover}
#SOpinionEC { background: url(../images/visitor/second_pinion/eyecatch.webp) no-repeat center / cover}
#medicalEC { background: url(../images/medical/eyecatch.webp) no-repeat center / cover}
#columnEC { background: url(../images/column/eyecatch.webp) no-repeat center / cover}
#symptomEC { background: url(../images/symptom/eyecatch.webp) no-repeat center / cover}
#forvetsEC { background: url(../images/forvets/forvets_eyecatch.webp) no-repeat center / cover}
#recruitEC { background: url(../images/recruit/recruit_eyecatch.webp) no-repeat center / cover}

.no-webp #aboutEC { background: url(../images/about/eyecatch.jpg) no-repeat center / cover}
.no-webp #staffEC { background: url(../images/about/staff_sample.jpg) no-repeat center / cover}
.no-webp #hospitalEC { background: url(../images/about/hospital_eyecatch.jpg) no-repeat center / cover}
.no-webp #visitorEC { background: url(../images/visitor/eyecatch.jpg) no-repeat center / cover}
.no-webp #puppyKittenEC { background: url(../images/visitor/puppy_kitten/eyecatch.jpg) no-repeat center / cover}
.no-webp #SOpinionEC { background: url(../images/visitor/second_pinion/eyecatch.jpg) no-repeat center / cover}
.no-webp #medicalEC { background: url(../images/medical/eyecatch.jpg) no-repeat center / cover}
.no-webp #columnEC { background: url(../images/column/eyecatch.jpg) no-repeat center / cover}
.no-webp #symptomEC { background: url(../images/symptom/eyecatch.jpg) no-repeat center / cover}
.no-webp #forvetsEC { background: url(../images/forvets/forvets_eyecatch.jpg) no-repeat center / cover}
.no-webp #recruitEC { background: url(../images/recruit/recruit_eyecatch.png) no-repeat center / cover}

/* Page Titles
------------------------------------------- */
.PTWrapp { width: 410px; position: relative; z-index: 2}
.PTWideWrapp { width: calc(100% - 10vw); position: absolute; top: 0; left: 5vw; z-index: 2}

.pageTitle, .pageTitle02, .MDPT, .MDPT02, #newsPTJP { font-size: 4.8rem; letter-spacing: .06em; margin: 0}
.pageTitle02 { font-size: 3.9rem; margin-top: 20px}
.MDPT02 { font-size: 4.5rem}

.PTBG { background: rgba(255,255,255,.7); padding: 9px 9px 9px 0; display: inline-block}

.PTEn, .MDPTEn, #newsPTEN { color: #f96600; font-size: 2.2rem; font-style: normal; letter-spacing: .1em; margin-top: 16px; display: block}
.MDPTEn { font-size: 2rem; letter-spacing: .075em; margin-top: 13px}

#officialPageTitle { color: #f96600; font-size: 5.8rem; letter-spacing: .035em; margin: 0}

#officialPTJP { color: #555; font-size: 2.4rem; font-style: normal; letter-spacing: .06em; margin-top: 10px; display: block}


/* Sub Titles
------------------------------------------- */
.pageST { font-size: 3.2rem; letter-spacing: .05em; margin: 0}

.PSTEn { color: #f96600; font-size: 1.6rem; font-style: normal; letter-spacing: .08em; margin: 14px 0 0 1px; display: block}

.st18, .st20, .st22, .NTLST, .MDHST, .MDHST02 { letter-spacing: .06em; margin: 0}
.st18 { font-size: 1.8rem}
.st20 { font-size: 2rem}
.st22, .NTLST { font-size: 2.2rem}

.MDHST { font-size: 2.6rem}
.MDHST02 { font-size: 2.4rem}

.st24 { font-size: 2.4rem; letter-spacing: .04em; margin: 0}

.NTLST { margin-top: 45px}

.stCenter { text-align: center}

.FCGreen { color: #009915}
.FCRose { color: #c56e77}
.FCBrown { color: #ae5e00}
.FCDBrown { color: #8e4e00}

/* Page Copy
------------------------------------------- */
.PCopy14, .PCopy15, .PCopy16, .PCopy17 { line-height: 2; letter-spacing: .05em}
.PCopy14 { font-size: 1.4rem} .PCopy15 { font-size: 1.5rem}
.PCopy16 { font-size: 1.6rem} .PCopy17 { font-size: 1.7rem}

.NTLNum { color: #64a69d; font-size: 3.8rem; font-style: normal; letter-spacing: 0; padding-right: 5px; vertical-align: -1px}

.PC900 { max-width: 900px !important}

.PTTPad01 { margin: 0; padding-top: 1em !important}

.PTTPad10 { margin: 0; padding-top: 10px !important}
.PTTPad20 { margin: 0; padding-top: 20px !important}
.PTTPad25 { margin: 0; padding-top: 25px !important}
.PTTPad30 { margin: 0; padding-top: 30px !important}
.PTTPad40 { margin: 0; padding-top: 35px !important}
.PTTPad50 { margin: 0; padding-top: 45px !important}
.PTTPad60 { margin: 0; padding-top: 55px !important}

.PTLPad40 { padding-left: 40px !important}
.PTLPad50 { padding-left: 5dvh !important}
.PTLPad55 { padding-left: 55px !important}
.PTLPad70 { padding-left: 70px !important}

.PTRPad40 { padding-right: 40px !important}
.PTRPad60 { padding-right: 60px !important}
.PTRPad70 { padding-right: 70px !important}

.PCopyCenter { text-align: center; margin: 50px 0 0}

.DBlock { display: block}

.cautSign { color: #f0442e; font-size: 1.2em; font-weight: bold; vertical-align: -.2em; padding-right: .15em}

.cautionText { padding-left: 1em; display: inline-block; position: relative}
.cautionText::before {
  content: '*'; position: absolute; top: -.1em; left: 0; color: #f0442e; font-size: 1.5em; font-weight: bold; padding-right: .2em}

/* Checkd List
------------------------------------------- */
.checkedList, .checkedList02 { margin: 35px 0 0; padding: 0 0 0 70px}
.checkedList02 { margin-top: 25px}
.flexC .checkedList{
  flex: 1;
}
.flexC .checkedList + .checkedList {
  padding-left: 20px;
}

.CHLItem, .WTBItem { font-size: 1.7rem; line-height: 1.6; letter-spacing: .06em; padding: 0 0 10px 35px; position: relative}
.CHLItem:last-of-type { padding-bottom: 0}
.WTBItem { font-size: 1.6rem; line-height: 2; padding-bottom: 1em}

.CHLItem::before, .CHLItem::after, .WTBItem::before, .WTBItem::after { content: ''; position: absolute}
.CHLItem::before, .WTBItem::before {
   top: 4px; left: 0; width: 16px; height: 16px; border-radius: 3px; border: 2px solid #22b373}
.WTBItem::before { top: 6px}

.CHLItem::after, .WTBItem::after {
  top: 6px; left: 4px; width: 16px; height: 5px; border-left: 3px solid #22b373; border-bottom: 2px solid #22b373;
  -webkit-transform: rotate(-45deg); transform: rotate(-45deg)}
.WTBItem::after { top: 8px}
.NoCheck::before, .NoCheck::after{
  content: none;
}

/* Bottom Banner Area
------------------------------------------- */
#topBottomBanner { padding: 70px 5vw 60px}

.TBotBWrapp { background: #fff; padding: 30px; border-radius: 5px}

.TBBST { font-size: 2.8rem; font-weight: 500; text-align: center; letter-spacing: .03em; margin: 10px 0 0}

#bottomBanner, #bottomBanner02 { padding: 60px 5vw}
#bottomBanner02 { background: #e0f0ee; border-bottom: 2px solid #fff}

.botBNArea { max-width: 1080px; margin: 30px auto 0}

.botBN, .BBIM { width: calc(33.33% - 20px); max-width: 340px; position: relative}

.BBNLink { color: #444; text-decoration: none; width: 100%; height: 100%; display: block}

.BBIM, .BBIM img { width: 100%; height: auto; border-radius: 5px; display: block}

.BBTit { font-size: 1.8rem; letter-spacing: .06em; margin: 1em 0 0}

.BBCopy { font-size: 1.5rem; line-height: 1.6; letter-spacing: .075em; margin: 10px 0 0}

.BBNLink:hover { color: #078}

.BBNLink .BBIM::after {
  content: ''; position: absolute; top: 0; left: auto; right: 0; background: rgba(0,0,0,.35);
  width: 0; height: 100%; border-radius: 5px; display: block}

.BBNLink:hover .BBIM::after { left: 0; right: auto; width: 100%}

/* -------------------------------------------
 Loader
------------------------------------------- */
#tp-loader { position: absolute; top: 0; left: 0; background: #e2e2e2; width: 100%; height: 100%; z-index: 100; }

#loader {
 position: absolute; top: 50%; left: 50%; color: #fff; text-align: center;
 width: 200px; margin: 15px 0 0 -100px; z-index: 101; }

@-webkit-keyframes loader { 0% { -webkit-transform: rotate(0deg); } 100% { -webkit-transform: rotate(360deg); }}
@keyframes loader { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); }}

.loader {
 width: 3rem; height: 3rem; margin: -1.5rem 0 0 -1.5rem; display: inline-block; vertical-align: middle;
 border: solid .25rem #f5f5f5; border-top-color: #ff6347; border-left-color: #ff6347;
 -webkit-border-radius: 50%; border-radius: 50%;
 -webkit-animation: loader 750ms linear infinite; animation: loader 750ms linear infinite; }

/* -------------------------------------------
 Top Page
------------------------------------------- */
#familyDoctor, #specializedTreatment, .infinitySign, .TBIco {
  background: url(../images/top/top.svg) no-repeat 0 0 / 890px 360px}

.topST { font-size: 3.4rem; letter-spacing: .06em; margin: 0}

.TSEN { color: #777; font-size: 1.6rem; font-style: normal; letter-spacing: .07em; margin-top: 8px; display: block}

#topTargetAnimal, #topMedSubject, #searchProblem, #ourStrengths { max-width: calc(1340px - 10vw); margin: 0 auto; padding: 70px 5vw}
#topMedSubject { padding-top: 0}
#ourStrengths { padding-bottom: 10px}

/* Top Banner */
#topEyecatch { background: #bbb; height: 780px; position: relative}

#topSlide { width: 100%; margin: 0 auto; overflow: hidden}

#topSlider {
  background: url(../images/top/slide03.jpg) no-repeat center / cover; width: 100%; height: 780px; position: relative}

/* Top Head Copy */
#topHeadCopy, #THEnCopy {
  position: absolute;  left: 7.5%;
  text-shadow: 0 1px 4px rgba(0,0,0,.85); color: #fff; font-size: 3.6rem; letter-spacing: .05em; margin: 0; z-index: 15}
#topHeadCopy { top: 33%}
#THEnCopy { bottom: 25%}

.thc01, .thc02 { display: block}
#topHeadCopy .thc02 { margin-top: 15px}

#THEnCopy { font-size: 2.3rem}
#THEnCopy .thc02 { margin-top: 9px}

.THOpen {
  position: absolute; top: 120px; right: 25px; background-color: #fff; color: #5e5e5e;
  font-size: 1.6rem; font-weight: 600; text-align: right; letter-spacing: .02em; padding: 6px 8px 5px; display: block}

.THOTime { font-weight: 500}
.THOTilde { font-size: 600; vertical-align: -1px; -webkit-transform: scale(.8,1.3); transform: scale(.8,1.3); display: inline-block}

/* Top Head Information */
#topHeadInfo { padding: 15px 6vw 15px 0}

.topNews { width: calc(50% - 6vw); max-width: 700px; padding-top: 40px; position: relative}

.topHour { background: #f2f2f2; width: calc(50% - 80px); padding: 40px 40px 40px 5vw; }

.THIST { color: #f96600; font-size: 3.6rem; letter-spacing: .04em; margin: 0}
.THIJP { color: #444; font-size: 1.6rem; margin-top: 5px; display: block}

.TNewsList { margin: 40px 0 0; padding: 0}

.TNItem { font-size: 1.5rem; letter-spacing: .02em; margin: 0 0 30px}

.TNListLink { justify-content: flex-start; gap: 0 50px; position: absolute; bottom: 40px; left: auto; width: 100%}

.TNBT { font-size: 1.5rem; margin: 0}

.TNLink { color: #555; text-decoration: none; display: inline-block}
.TNLink:hover { color: #339299; -webkit-transform: translate(1px,-1px); transform: translate(1px,-1px)}

.TNTime { font-size: 1.4rem; letter-spacing: .08em}

.TNKind {
  color: #fff; font-size: 1.3rem; text-align: center; letter-spacing: 0;
  width: 6.2em; margin: 0 12px 0 8px; padding: 3px 0 4px; vertical-align: 1px; display: inline-block}

.TNNews { background: #69a53e}
.TNColumn { background: #f9851e}

.TNLink:hover .TNNews, .TNLink:hover .TNColumn { background: #00a9b2}

/* Top Calender */
#topCalender { margin-top: 0}

.topCal { width: 100%; border-collapse: collapse}

.TCalSec { border-top: 2px solid #b2b2b2}

.topCal th, .topCal td { font-size: 1.5rem; text-align: center; padding: 10px 5px}

.topCal .openTime { font-size: 1.8rem; text-align: left; letter-spacing: .08em; width: 130px}
.OTChil { font-size: 1.4rem}
.OP02 .OTChil { margin: 0 .165em}

.openH { width: 20px; height: 20px; border: 3px solid #666; border-radius: 50%; display: inline-block}

.biweekly {
  background: #666; width: 26px; height: calc(26px / 2 * tan(60deg)); margin-top: -2px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%); display: inline-block; position: relative}
.biweekly::after {
  content: ''; position: absolute; top: 5px; left: 0;
  background: #f2f2f2; width: 17px; height: calc(17px / 2 * tan(60deg));
  clip-path: polygon(50% 0, 100% 100%, 0 100%); display: inline-block; position: relative}

.partTime { font-size: 1.5rem; letter-spacing: .05em}

.TCalNotice { font-size: 1.4rem; line-height: 1.8; letter-spacing: .075em; margin: 8px 0 0}

.TCNoticeSign { color: #f03e00; font-size: 1.9rem; margin-right: 5px; vertical-align: -7px}

.TCalBT { font-size: 1.5rem; text-align: center; margin: 10px 0 0; z-index: 1; position: relative}

/* Infinity Message */
#infinityMessage { padding: 70px 0; position: relative}

.infinityContents { width: 900px; margin: 0 auto; position: relative}

#familyDoctor, #specializedTreatment { width: 360px; height: 360px}

#specializedTreatment { background-position: -380px 0}

.infinitySign {
  position: absolute; top: 50%; left: 50%; background-position: -750px 0;
  width: 140px; height: 80px; margin: -40px -70px; display: block}

.IMSquare01, .IMSquare02, .IMSquare03, .IMSquare04 { content: ''; position: absolute; opacity: .7; display: block}

.IMSquare01, .IMSquare03 { background: #d6facd}
.IMSquare02, .IMSquare04 { background: #caf0fc}

.IMSquare01 { top: 35px; left: 0; width: 112px; height: 112px}
.IMSquare02 { top: 103px; left: 68px; width: 84px; height: 84px}
.IMSquare03 { bottom: 35px; right: 0; width: 112px; height: 112px}
.IMSquare04 { bottom: 103px; right: 68px; width: 84px; height: 84px}

/* Top Greetings */
#topGreetings {
  background: url(../images/top/top_doctor.jpg) no-repeat left 48% / 480px 427px;
  width: 100%; max-width: 1340px; margin: 0 auto; padding-block: 70px; min-height: 427px; position: relative}

.TGreetInner { padding: 0 5vw}

#TGreetST { width: 200px}

#TGreetContents { min-width: 640px; max-width: 65%}

#TGCatch { color: #0082b2; font-size: 2.3rem; letter-spacing: .05em; margin: 70px 0 0}

.TGCatch02 { color: #394; margin-top: 12px; display: block}

.TGCopy { line-height: 2.2; margin: 30px 0 0}

.topGreetBT { margin-top: 35px}

/* Our Strengths */
.OStrengthItem01, .OStrengthItem02 { background: #fff; margin-top: 50px; padding: 30px; border-radius: 5px}
.OStrengthItem01 { padding-left: 50px}
.OStrengthItem02 { padding-right: 50px}

.OSIBlock { width: calc(100% - 460px)}

.OSITit { font-size: 2.5rem; letter-spacing: .06em; margin: 20px 0 0}

.OSICopy { font-size: 1.5rem; line-height: 1.8; letter-spacing: .06em; margin: 45px 0 0}

.OSIBT { letter-spacing: .08em; margin-top: 50px}

.OSIIM { width: 400px; height: 300px}

@media (max-width: 1249px) { .pcNBlock { margin: 8px 0 0 1em; display: block} }

/* Search by Problem */
.topProblemList { margin: 30px auto 0; justify-content: flex-start; gap: 0 calc(2vw * 4 / 3)}

.TPItem { width: calc(25% - 2vw); height: 220px; margin: 2.65vw 0 0}

.TBLink {
  display: flex; justify-content: center; align-items: center; color: #333;
  text-decoration: none; text-align: center; width: 100%; height: 100%; border-radius: 6px; z-index: 1; position: relative}

.TBCopy { font-size: 1.9rem; line-height: 1.5; width: 100%; display: block}
.TBLink:hover .TBCopy { color: #089; -webkit-transform: translateY(-2px); transform: translateY(-2px)}

.TBDep { color: #555; font-size: 1.6rem; margin-top: 5px; display: block}
.TBDep::before, .TBDep::after { color: #7e7e7e; font-size: 1.5rem; vertical-align: 1px}
.TBDep::before { content: "- "} .TBDep::after { content: " -"}
.TBLink:hover .TBDep { color: #f0771e}

.TBLink::before, .TBLink::after {
  content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 6px; display: block}
.TBLink::before { background: #e5e5e5; z-index: -2}
.TBLink::after { background: #d7f2f2; -webkit-transform: scale(0); transform: scale(0); z-index: -1}
.TBLink:hover::after { -webkit-transform: scale(1); transform: scale(1)}

.TBIco {
  position: absolute; top: 28px; left: 50%;
  background-position: -800px -150px; width: 30px; height: 30px; margin-left: -15px; display: block}

.TBLink:hover .TBIco { top: 28px}

/* Bottom Staff */
#botStaff { background: #b7b7b7; padding: 60px 0}

.BStaffST { font-size: 4rem; text-align: center; letter-spacing: .08em; margin: 0}

#botStaffSlide { height: 290px; margin-top: 40px; position: relative}

#BSSlideContainer { max-width: 1340px; margin: 0 auto}

.sliderItem { margin: 0 5px}

/* -------------------------------------------
  About
------------------------------------------- */
#ebmImage, .TAniIcon, .TRessItem { background: url(../images/about/about.svg) no-repeat 0 0 / 372px 570px}

#aboutHeadCopy, #hospitaltHeadCopy { font-size: 2.2rem; line-height: 1.8; letter-spacing: .05em; margin: 9vw 0 0}

.evidenceBWrapp { margin-top: 50px}

.evidenceBased { width: calc(100% - 440px)}

#ebmImage { width: 372px; height: 348px}

.muchAsPossible { margin-top: 30px}

.MSPCopy, .OFCopy { max-width: 920px}

.OFFIPBT { padding: 15px 0 0 70px}

#topSpecializedOutpatient, #ourSpecializedOutpatient { background: #fff; margin: 40px auto 0; padding: 40px}

#topSpecializedOutpatient { width: calc(100% - 80px); margin-top: 50px; border-radius: 5px}

.OSOST { color: #606060; font-size: 2rem; text-align: center; letter-spacing: .035em; margin: 0}
.OSOST:nth-of-type(2n) {
  color: #8e805c;
}
.OSOST:not(:first-child) {
  margin-top: 40px;
}
#topOSOST02 { color: #8e805c}

#OSOList { width: 860px; margin: 0 auto; padding: 0; justify-content: flex-start; gap: 0 40px}
.topOSOList { width: calc(100% - 60px); margin: 0 auto; padding: 0; justify-content: flex-start; gap: 0 15px}

.OSOItem { font-size: 1.7rem; text-align: center; letter-spacing: .04em; width: 260px; margin-top: 30px}
#topSpecializedOutpatient .OSOItem { width: calc(33.33% - 10px); margin-top: 15px}

.OSOLink { color: #fff; text-decoration: none; padding: 16px 0; display: block; overflow: hidden; cursor: pointer; position: relative; z-index: 1}
.win .OSOLink { padding: 16px 0 17px}

.OSOLink::before, .OSOLink::after { content: ''; position: absolute; top: 0; height: 100%; display: block}
.OSOLink::before { left: 0; background: #828282; width: 100%; z-index: -2}
.OSOLink::after { left: auto; right: 0; background: #2ea2a9; width: 0; z-index: -1}
.OSOLink:hover::after { left: 0; right: auto; width: 100%}
.topOSOList:nth-of-type(2n) .OSOLink::before {
  background: #999589;
}

#TOSOL02 .OSOLink::before { background: #999589}

.targetAnimal { width: 760px; margin: 40px auto 0; padding: 0}

.TAniItem { background: #8c887c; width: 160px; height: 160px; border-radius: 50%; position: relative}
#TTAni .TAniItem { background: rgb(57,145,180)}

.TAniKind {
  position: absolute; top: 95px; left: 0;
  color: #fff; font-size: 1.8rem; text-align: center; letter-spacing: .03em; width: 100%}

.TAniIcon { position: absolute; top: 30px; left: 50%; display: block}
#TAniDog { background-position: -250px -400px; width: 50px; height: 42px; margin: 5px 0 0 -26px}
#TAniCat { background-position: -320px -400px; width: 50px; height: 48px; margin-left: -25px}
#TAniRabbit { background-position: -250px -460px; width: 40px; height: 49px; margin-left: -20px}
#TAniHamster { background-position: -320px -460px; width: 44px; height: 33px; margin: 14px 0 0 -22px}

/* Wellness Club */
#WClubInfo { width: 940px; margin: 50px auto 0}

.wellnessClubWrapp { background: #fff; padding: 60px 70px 80px; margin: 50px auto 0}

#WClubST { color: #368f00; font-size: 3rem; text-align: center; margin: 0; padding-bottom: 16px; position: relative}
#WClubST::before, #WClubST::after { content: ''; position: absolute; left: 50%; width: 11.6em; margin-left: -5.8em}
#WClubST::before { bottom: 2px; background: #a2d9ab; height: 4px}
#WClubST::after { bottom: 0; background: #88b277; height: 2px}

.WSOMAH { color: #f96600; font-size: 3.3rem; font-style: normal; letter-spacing: .06em; vertical-align: -1px}

.WCBenefitsCopy { text-align: center; letter-spacing: .05em; margin: 40px 0 0}

.threeReassurance { font-size: 2.2rem; text-align: center; letter-spacing: .06em}
.TROMAH { font-size: 2.4rem; font-style: normal; padding-right: 1px; vertical-align: -1px}
.TRNum { color: #f96600; font-size: 3.3rem; font-style: normal; margin: 0 2px; vertical-align: -3px}

#TReassuranceList { width: 640px; height: 220px; margin: 30px auto 0; position: relative}

.TRessItem { position: absolute; top: 0; background-position: 0 -350px; text-align: center; width: 220px; height: 220px}
.TRessItem:nth-of-type(1) { left: 0; z-index: 1}
.TRessItem:nth-of-type(2) { left: 50%; margin-left: -110px; z-index: 2}
.TRessItem:nth-of-type(3) { right: 0; z-index: 3}

.TRessItem::after {
  content: ''; position: absolute; top: 42px; left: 50%; width: 24px; height: 11px; margin-left: -13px;
  border-left: 6px solid #37d94e; border-bottom: 6px solid #37d94e; -webkit-transform: rotate(-45deg); transform: rotate(-45deg)}

.TRICopy { position: absolute; top: 88px; left: 0; color: #006077; font-size: 2.6rem; line-height: 1.4; letter-spacing: .06em; width: 100%; }
.TRISub { font-size: 2.2rem; display: block}

#WCBenefitsDetail { width: 800px; margin: 50px auto 0}

.WCBDst { font-size: 2.4rem; margin: 0}
.WCBOMAH { color: #f96600; font-size: 2.7rem; letter-spacing: .06em; vertical-align: -1px}

.WCBSTTax { font-size: 1.7rem; font-weight: 500; margin-left: .5em}

#WCBDList, #MShipDetail { width: 100%; margin-top: 30px; border-collapse: collapse}

#WCBDList th, #WCBDList td, #MShipDetail th, #MShipDetail td {
  font-size: 1.6rem; text-align: center; line-height: 1.3; letter-spacing: .05em; padding: 12px 0}
#WCBDList tr { border-bottom: 2px solid #fff}
.WCCat { border-top: 6px solid #fff}

.kindLeft { background: #e5e5e5; width: 356px}
.kindCenter { background: #ccedd2; color: #156222}
.kindRight { background: #facaa8; color: #8c3a1c}

.thLeft, .MSTH { background: #f3f3f3; width: 356px}
.thCenter { background: #f1faf1; color: #156222}
.thRight, .MSTD { background: #fdefe5; color: #8c3a1c}

.kindCenter, .kindRight, .thCenter, .thRight { width: 200px; border-left: 5px solid #fff}

#WCBDList .tdW { font-size: 1.4rem}

.membershipST { color: #368f00; font-size: 2.4rem; letter-spacing: .05em; margin: 50px 0 0}

.membershipGuide { font-size: 2rem; letter-spacing: .05em; margin: 30px 0 0}

.MGLine { color: #368f00; font-size: 2.4rem; margin: 0 2px; vertical-align: -1px}

#MShipDetail tr { border-bottom: 5px solid #fff}

#MShipDetail th, #MShipDetail td { padding: 18px 0}

#MShipDetail .MSKindLeft { background: #e5e5e5; letter-spacing: .1em; text-indent: .1em}
#MShipDetail .MSKindRight {
  background: #facaa8; color: #8c3a1c; letter-spacing: 1em; text-indent: 1em}

.MSKindLeft, .MSTH { width: 200px}
.MSKindRight, .MSTD { border-left: 5px solid #fff}

.MSList { margin: 0; padding: 0}

.MSItem { margin-top: 10px}

.membershipInfo { font-size: 1.9rem; letter-spacing: .06em; margin: 30px 0 0}

.membershipGuide .spNFalse { padding-right: .25em}

.MSIOMAH { color: #f96600; font-size: 2.1rem; letter-spacing: .06em; margin-right: 2px; vertical-align: -1px}

/* Staff Page */
#staffHeadCopy { font-size: 2.6rem; line-height: 1.8; letter-spacing: .05em; margin: 9vw 0 0}

#staffHSubCopy { font-size: 1.8rem; line-height: 2; letter-spacing: .06em; margin: 50px 0 0 28px}

.staffWrapp { max-width: 1280px; margin: 0 auto; padding: 70px 5vw}

/* KIZAKI */
.hospitalDirectorWrapp { margin-top: 20px}

.HDWMessage, .HDMDetail { width: calc(50% - 40px)}

#HDMName { font-size: 2.4rem; letter-spacing: .06em; margin: 80px 0 0}
.HDMPost { font-size: 1.8rem; margin-bottom: 18px; display: block}
.HDMNEn { font-size: 1.5rem; letter-spacing: .025em; margin-left: 15px}

.HDMTA { width: 100%; border-collapse: collapse}

.HDMTA th, .HDMTA td { font-size: 1.5rem; text-align: left; line-height: 1.75; letter-spacing: .05em; padding: 10px 12px}
.HDMTA th { font-weight: normal; white-space: nowrap}

.HDMTA .HDMThead {
  background: #f0f0f0; font-size: 1.6rem; font-weight: 500; text-align: center; padding: 9px 12px; border-bottom: 4px solid #fff}

.HDMTA .TDAffiliated { padding-left: 20px}

.HDMTA tr:nth-of-type(odd) th { background: #eee}
.HDMTA tr:nth-of-type(even) td { background: #f2f2f2}

@media (max-width: 1280px) { .TDAffiliated .spNBlock { display: block} }

.interviewBN { text-align: center; margin: 30px 0 0}

.interviewBN a { display: inline; margin: 0 1rem;}

.IBNLink:hover { opacity: .7; -webkit-transform: translateY(-2px); transform: translateY(-2px)}

.HDWMCatch { line-height: 1.8; margin: 80px 0 0}

.HDWMCopy { margin: 8px 0 0}

/* Other Staff */
.staffKind { font-size: 3.2rem; letter-spacing: .08em; margin: 0}
.SKindSec { font-size: 2.5rem; margin: 0 -.6em 0 -.35em}

.SKindEn {
  color: #f96600; font-size: 1.8rem; font-style: normal; letter-spacing: .06em; margin-left: 15px; vertical-align: -1px; display: inline-block}

.staffList { margin-top: 10px}

.staffItem { background: #fff; width: calc(50% - 20px); margin-top: 40px; padding-bottom: 25px}

.SIHead { align-items: center; width: 100%}

.SIPhoto, .SIPhoto02 { width: 250px; max-height: 310px; margin: 0}
.SIPhoto02 { height: 250px}
.SIPhoto img, .SIPhoto02 img{
  height: auto;
  width: 100%;
}

.staffName, .staffName02, .SNPartTime, .studentStaff {
  font-size: 2rem; letter-spacing: .06em; width: calc(100% - 308px); margin: 0; padding-right: 18px}
.studentStaff { font-size: 1.8rem; line-height: 1.4}
.SNPartTime { font-size: 1.8rem; line-height: 1.6}

.SNPost, .SNNurse { font-size: 1.5rem; margin-bottom: 10px; display: block}
.SNPSec { font-size: 1.3rem; font-weight: 400; line-height: 1.5; letter-spacing: .04em; padding: 6px 0 0 5px; display: block}
.SNNurse { font-weight: 400; line-height: 1.6} .SNNurseSec { font-size: 1.3rem; margin-left: -.35em}
.SNameEn { color: #666; font-size: 1.3rem; font-style: normal; letter-spacing: .04em; margin-top: 12px; display: block}
.studentStaff .SNameEn { margin-top: 2px}
.SNLeave{
  background: #eee;
  font-size: 1.5rem;
  margin: 0 0 10px;
  padding: .3em;
  text-align: center;
}

.SIInfo { padding: 15px 40px}

.staffMessage, .staffGuide, .SISpecialized { font-size: 1.5rem; line-height: 1.6; letter-spacing: .06em; margin: 20px 0 0}
.staffGuide { line-height: 2}

.SIBio { margin: 20px 0 0; padding: 0}
.SIBKind, .SIBItem { font-size: 1.4rem; line-height: 1.6; letter-spacing: .05em; margin: .33em 0 0}
.SIBKind { font-size: 1.5rem; font-weight: 500; letter-spacing: .3em}
.SIBItem { padding-left: 1.5em}

.SIYear01 { width: 5.5em; display: inline-block}
.SIYear02 { width: 8em; display: inline-block}
.SIYear03 { display: block}

@media (min-width: 1260px) { .studentStaff br{ display: none}}

/* Facilities&Equipment */
.hospitalWrapp .innerWrapp + .innerWrapp{
  border-top: 3px solid #FFF;
}
.hospitalListWrapp{
  background: #FFF;
  padding: 35px;
}
.hospitalList{
  gap: 20px 32px;
  justify-content: flex-start;
}
.hospitalItem{
  width: calc((100% - (32px * 2)) / 3);
}
.hospitalItem.is-hidden{
  display: none;
}
.hspImage{
  border-radius: 6px;
  overflow: hidden;
  height: 215px;
  width: 315px;
  max-width: 100%;
  margin-bottom: 20px;
}
.hspImage img{
  height: 100%;
  width: 100%;
  object-fit: cover;
  display: block;
}
.hspName,.hspSubName,.hspSubDesc{
  font-family: "Figtree", "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: .04em;
  margin: 0;
  line-height: 1.2;
}
.hspName{
  font-size: 1.7rem;
  margin-bottom: 2px;
}
.hspSubName{
  font-size: 1.6rem;
  min-height: 20px;
}
.hspSubDesc{
  font-size: 1.4rem;
  line-height: 1.8;
  margin-top: 10px;
  margin-bottom: 10px;
}

.moreBtnWrap{
  margin: 35px 25px;
  text-align: center;
}
.moreBtn{
  background-color: #f0f0f0;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  font-weight: 700;
  padding: 12px 50px 12px 22px;
  position: relative;
  min-width: 165px;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.3s;
}
.moreBtn:hover{
  opacity: .8;
}
.moreBtn::after{
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 3px solid #4d4d4d;
  border-bottom: 3px solid #4d4d4d;
  transform: translateY(-70%) rotate(45deg);
  transition: transform 0.3s;
}
.moreBtn.is-active::after{
  transform: translateY(-30%) rotate(-135deg);
}
.moreBtn:hover::after{
  transform: translateY(-50%) rotate(45deg);
}
.moreBtn.is-active:hover::after{
  transform: translateY(-50%) rotate(-135deg);
}


/* -------------------------------------------
  For Visitor
------------------------------------------- */
#visitorTitEn .onChar8 { width: 8px}

.BVResIco, .BVTelIco, .VTAIco, .VPSIco, .VPSIco02 { background: url(../images/visitor/visitor.svg) no-repeat 0 0 / 246px 100px}

#visitorSecOpinionBT { margin-top: 11vw}

#VSOLink, #FSPKLink, #FSSOKLink { font-size: 1.7rem; letter-spacing: .05em; padding: 17px 65px 17px 30px}
#VSOLink::before, #FSPKLink::before, #FSSOKLink::before { background: #777}

#VSOLink .TNLSign::before, #VSOLink .TNLSign::after, #FSPKLink .TNLSign::before, #FSPKLink .TNLSign::after,
#FSSOKLink .TNLSign::after { background: #999}
#VSOLink:hover .TNLSign::before, #VSOLink:hover .TNLSign::after,
#FSPKLink:hover .TNLSign::before, #FSPKLink:hover .TNLSign::after, #FSSOKLink:hover .TNLSign::after { background: #2e99bb}

.visitorST { font-size: 2.4rem; letter-spacing: .04em; margin: 0}

.FSPKGuide { display: flex; justify-content: flex-start; margin-top: 15px; padding-left: 50px}

#FSPKBT { margin: 15px 0 0 25px}

/* Before Visiting */
#FSSecOpinion, #beforeVisiting, #visitPreparation { padding-bottom: 60px}

.beforeVGuide:first-of-type { padding-top: 10px}
.beforeVGuide:last-of-type { background: #fff; margin-top: 45px; padding: 50px 70px; border: 2px solid #ffc0ae; border-radius: 5px}

.BVGInfo { width: calc(100% - 50px)}

.BVGLink { width: 640px; padding: 25px 0 0 75px}

.BVGReserve, .BVGTel { font-size: 1.7rem; text-align: center; letter-spacing: .05em; width: 300px; margin: 0}
.BVGTel { font-size: 2rem; letter-spacing: .1em}

.BVResBT, .BVTelBT {
  color: #fff; text-align: center; text-decoration: none; text-indent: 30px; padding: 15px 0;
  display: block; position: relative; z-index: 1; cursor: pointer}
.BVTelBT { text-indent: 20px; padding: 14px 0}

.BVR24 { font-size: 1.4rem; margin-left: -5px}

.BVResBT::before, .BVResBT::after, .BVTelBT::before, .BVTelBT::after, .BVBTShadow {
  content: ''; position: absolute; top: 0; height: 100%; display: block}

.BVResBT::before, .BVTelBT::before { left: 0; background: #fc792e; width: 100%; z-index: -2}
.BVTelBT::before { background: #52a7d2}
.BVResBT::after, .BVTelBT::after { left: auto; right: 0; background: #52a7d2; width: 0; z-index: -1}
.BVTelBT::after { background: #fc792e}
.BVResBT:hover::after, .BVTelBT:hover::after { left: 0; right: auto; width: 100%}

.BVBTShadow { top: 3px; left: 3px; background: #ae884e; width: 100%; z-index: -10}
.BVTelBT .BVBTShadow { background: #4482ae}
.BVResBT:hover .BVBTShadow, .BVTelBT:hover .BVBTShadow { top: -2px; left: -2px}

.BVResIco, .BVTelIco { position: absolute; left: 50%; display: block}
.BVResIco { top: 11px; background-position: -220px 0; width: 26px; height: 26px; margin-left: -6.2em}
.BVTelIco { top: 17px; background-position: -220px -50px; width: 16px; height: 16px; margin-left: -4em}

.BVResBT:hover .BVResIco { transform: rotate(15deg)}
.BVTelBT:hover .BVTelIco { transform: rotate(20deg) translate(3px,-1px)}

#BVGuideNotice { margin: 12px 0 0; padding: 0}

.BVGNST { color: #95622e}

.BVGNItem { padding: 12px 0 0 1em}
.BVGNItem::before { content:'❖'; color: #d35; font-size: 1rem; margin: 0 5px 0 -15px; vertical-align: 1px}

/* Visitor target Animal */
#VTtargetAnimal { padding-bottom: 60px}

.VTAnimal { width: 760px; margin: 30px auto 0; padding: 0}

.VTAItem { background: #8c887c; width: 160px; height: 160px; border-radius: 50%; position: relative}

.VTAKind {
  position: absolute; top: 95px; left: 0;
  color: #fff; font-size: 1.8rem; text-align: center; letter-spacing: .03em; width: 100%}

.VTAIco { position: absolute; top: 30px; left: 50%; display: block}
#VTADog { width: 50px; height: 42px; margin: 5px 0 0 -26px}
#VTACat { background-position: -60px 0; width: 50px; height: 48px; margin-left: -25px}
#VTARabbit { background-position: -120px 0; width: 40px; height: 49px; margin-left: -20px}
#VTAHamster { background-position: -170px -5px; width: 44px; height: 33px; margin: 14px 0 0 -22px}

.VPSKind { width: 70px; position: relative}

.VPSGuide { width: calc(100% - 70px)}

.VPSIco, .VPSIco02 { position: absolute; top: 0; left: 0; display: block}
.VPSIco02 { top: 60px}

#VPSDog .VPSIco { background-position: 0 -50px; width: 50px; height: 42px}
#VPSCat .VPSIco { background-position: -60px -50px; width: 50px; height: 48px}
#VPSRabbit .VPSIco { left: 2px; background-position: -120px -50px; width: 40px; height: 49px}
#VPSRabbit .VPSIco02 { background-position: -170px -55px; width: 44px; height: 33px}

.VPreST { color: #3e8900; font-size: 2rem; letter-spacing: .03em; margin: 0}

#VPSDog .VPreST { padding-top: 10px}
#VPSCat .VPreST, #VPSRabbit .VPreST { padding-top: 15px}

.VPSCopy { padding-right: 80px}

.VPSNWrapp { background: #ffe5d9; margin: 40px 70px 0; padding: 10px 30px 20px}

.VPSNotice { margin: 3px 0 0; padding: 0}

.VPSNItem { font-size: 1.4rem; line-height: 1.75; letter-spacing: .06em; margin: 0; padding: 10px 0 0 17px; position: relative}

.VPSNItem::before, .WTBNotice::before { content: '*'; position: absolute; top: 7px; left: 2px; color: #f21e3e; font-size: 2rem}
.WTBNotice::before { top: -1px}

/* What To Bring */
#WhatToBring { padding-bottom: 70px}
.WTBlingWrapp { width: 800px; margin: 40px auto 0}

.WTBlingList { margin: 0; padding: 0}

.WTBNotice { font-size: 1.4rem; margin-top: 8px; padding-left: 17px; display: block; position: relative}

#petInsurance { width: 670px; margin: 20px auto 0}

.insuranceItem { width: 310px}

.PIBanner, .PICard { background: url(../images/visitor/insurance.png) no-repeat 0 0 / 630px 198px}

.PICard { width: 312px; height: 198px}
#PICIpet { background-position: -320px 0}


/* Welcoming a Puppy or Kitten
------------------------------------------- */
#PICD03 { display: none}

#PKPTJP .onChar7 { font-size: 3.6rem; margin: 0 -.25em}
#PKPTJP .onChar16 { margin: 0 -.1em}
#PKPTEN .onChar14, #PKPTEN .onChar16, #PKPTEN .onChar22, #PKPTEN .onChar25 { width: 6px}

#puppyKHeadCopy { font-size: 1.6rem; line-height: 2; letter-spacing: .06em; width: 52.5%; margin: 100px 0 0}

@media (min-width: 1280px) { #puppyKHeadCopy { width: 50%}}
@media (min-width: 1450px) { #puppyKHeadCopy br{ display: none}}

.puppyKittenSchedule { width: 100%; margin-top: 40px}
.puppyKittenSchedule:last-of-type { margin-top: 20px}

.preventNum { color: #009045; font-size: 1.7rem; font-weight: 600; margin-right: 4px; vertical-align: -1px}

#fivePrevention { width: 950px; margin: 40px auto 0; padding: 0}

.fivePItem { font-size: 1.7rem; text-align: center; width: 190px; height: 190px}

.fivePILink {
  display: flex; align-items: center; color: #fff; text-decoration: none; letter-spacing: .05em;
  width: 190px; height: 190px; border-radius: 50%; overflow: hidden; cursor: pointer; position: relative}

.fivePILink::after {
  content: ''; position: absolute; top: 5px; left: 5px;
  width: 176px; height: 176px; border-radius: 50%; border: 2px solid #fff}

#FPI01 { background: #f27995} #FPI02 { background: #f79b4b} #FPI03 { background: #55be89}
#FPI04 { background: #5c8fe6} #FPI05 { background: #9672bf}

.FPIKind { width: 100%; height: 1em; display: block}

.fivePILink:hover { background: #8e8e8e !important}

#PKWelnessBT { margin-top: 10px}
#PKWelnessBT .LBBlack { padding: 17px 60px 17px 20px}
#PKWelnessBT .LBBlack::before { background: #4ea959}
#PKWelnessBT .TNLSign::before, #PKWelnessBT .TNLSign::after { background: #72b985}

#personInCharge { background: #f2f2f2; width: 760px; margin: 50px auto 0; padding: 50px 70px}

.personICHead { width: 240px}

.PICIM { width: 240px; height: 170px}

.PICName { margin: 20px 0 0}

.personICMain { width: 420px; margin-top: 30px}

.PICMCopy { margin-top: 50px}

.PICData { font-size: 1.3rem; line-height: 1.6; margin: 20px 0 0}
.PICData dd { margin: 0 0 0 1em}


/* Scond Opinion
------------------------------------------- */
#SOpinionJP { letter-spacing: 0}

#SOpinionEN .onChar11 { width: 6px}

#SOpinionHeadCopy {
  background: rgba(255,255,255,.8); font-size: 1.6rem; line-height: 2; letter-spacing: .06em;
  width: 52.5%; margin: 90px 0 0; padding: 9px 9px 9px 0}

@media (min-width: 1280px) { #SOpinionHeadCopy { width: 50%}}
@media (min-width: 1450px) { #SOpinionHeadCopy br{ display: none}}


.checkedCopy { width: 25px; height: 17px; display: inline-block; position: relative}
.checkedCopy::before {
  content: ''; position: absolute; top: 6px; left: 5px;
  width: 12px; height: 5px; border-left: 3px solid #22b373; border-bottom: 3px solid #22b373;
  -webkit-transform: rotate(-45deg); transform: rotate(-45deg); display: block}

.exInspectionData { background: #f2f0e9; width: 500px; margin: 40px auto 0; padding: 30px 40px 20px}

.exIDST { color: #664e33; font-size: 1.7rem; letter-spacing: .05em; margin: 0}

#EXIDList { margin: 20px 0 0; padding: 0 0 0 11px}

#EXIDList li { font-size: 1.5rem; letter-spacing: .06em; margin: 10px 0}
#EXIDList li::before { content: '■'; color: #c5b097; font-size: 1.3rem; margin-right: 2px}

.SOSpecializedList { background: #fff; width: 900px; margin: 40px auto 0; padding: 40px}


/* -------------------------------------------
  Medical
------------------------------------------- */
/* Medical Main Page */
.GMNIco, .GMNIcoW, .SPMIco { background: url(../images/medical/medical_ico.svg) no-repeat 0 0 / 236px 136px}

#medicalHeadCopy {
  background: rgba(255,255,255,.8); font-size: 1.6rem; line-height: 2; letter-spacing: .06em;
  width: 38.5em; margin: 90px 0 0; padding: 9px 0}

#searchSymptomsLBT { text-align: center; margin: 70px 0 0}
#ToTeachersBT { text-align: center; width: calc(50% - 12px); margin: 0}
#searchSymptomsLBT #VSOLink { font-size: 2.4rem}
#ToTeachersBT #VSOLink {font-size: 2.4rem;  width: calc(100% - 115px); margin-top: 21px; padding: 61px 75px 65px 40px; border-radius: 6px}
#ToTeachersBT #VSOLink::before { background: #888}

#searchSymptomsLBT .TNLSign, #ToTeachersBT .TNLSign { margin-top: -8px}

#generalMNavList { margin: 0 auto; padding: 10px 0 0}

.GMNItem { width: calc(33.33% - 25px); height: 190px; margin-top: 36px}

.GMNLink, .SPMLink {
  color: #444; text-decoration: none; width: 100%; height: 100%;
  display: block; position: relative; z-index: 1; cursor: pointer; overflow: hidden}

.GMNLink .graySign { margin-top: -14px;}

.GMNLink::before, .GMNLink::after, .SPMLink::before, .SPMLink::after {
  content: ''; position: absolute; top: 0; height: 100%; border-radius: 6px; display: block}

.GMNLink::before, .SPMLink::before { background: #fff; width: 100%; z-index: -2}
.SPMLink::before { background: #f2f2f2}
.GMNLink::after, .SPMLink::after { left: auto; right: 0; background: #b5e5f5; width: 0; z-index: -1}
.GMNLink:hover::after, .SPMLink:hover::after { left: 0; right: auto; width: 100%}

.GMNKind, .GMNKindW, .SPMKind, .SPMKindW {
  position: absolute; top: 82px; left: 0; font-size: 2rem; text-align: center;
  text-shadow: 1px 1px 0 rgba(255,255,255,.7); letter-spacing: .06em; text-indent: .03em; width: 100%; margin: 0}
.GMNKindW { font-size: 1.8rem; line-height: 1; text-indent: -10px;}

.GMNInfo {
  font-size: 1.4rem; line-height: 1.6; letter-spacing: .05em;
  width: calc(100% - 4.4em); margin-top: 20px; padding: 0 2.2em; display: block}

.GMNIco, .GMNIcoW {
  position: absolute; top: 24px; left: 50%; width: 36px; height: 40px; display: block;
  -webkit-transform: translateX(-50%); transform: translateX(-50%)}
.GMNIcoW { top: 30px}

.GMNLink:hover .GMNIco, .GMNLink:hover .GMNIcoW, .SPMLink:hover .SPMIco { margin-top: -3px}

@media (max-width: 1125px) { .GMNInfo.GMNI01 { width: calc(100% - 3em); padding: 0 1.5em}}
@media (max-width: 1172px) { .GMNInfo.GMNI02 { width: calc(100% - 3em); padding: 0 1.5em}}

#ophthIco { background-position: -50px 0}
#vaccIco { background-position: -100px 0}
#contracepIco { background-position: -150px 0}
#spayIco { background-position: -200px 0}
#pulmonoIco { background-position: -199px -96px}

#specialMedNavi { padding-top: 70px; border-top: 3px solid #fff}

#specialMNList { align-items: center; background: #fff; margin-top: 55px; padding: 10px 35px 35px}

.SPMItem { width: calc(50% - 12px); height: 150px; margin-top: 22px}

.SPMKind, .SPMKindW { top: 30px; left: 90px; text-align: left; line-height: 1.5; width: calc(100% - 150px)}
#SPMVcc { top: 20px}

.SPMInfo, .SPMInfoW, .SPSVCC { font-size: 1.4rem; margin-top: 12px; display: block}
.SPMInfoW { margin-top: 5px} .SPSVCC { color: #855a2e; margin-top: 2px}

.SPMIco { position: absolute; top: 57px; left: 30px; width: 40px; height: 36px; display: block}
#cardioIco { background-position: 0 -50px}
#uroloIco { background-position: -50px -50px}
#oncoloIco { background-position: -100px -50px}
#dentIco { background-position: -150px -50px}
#dermatoIco { background-position: -200px -50px}
#orthopIco { background-position: 0 -100px}
#softIco { background-position: -50px -100px}
#trainingIco { background-position: -100px -100px}
#radioIco { background-position: -148px -100px}

/* Medical Individual　Page Title */
#urologyPTEn .onChar15 { width: 6px}

#VaccinatPT { margin-left: -4px}
#VaccinatPT .onChar5, #VaccinatPT .onChar7 { letter-spacing: 0}
#VaccinatPT .onChar6 { margin: 0 -3px}
#VaccinatPT .onChar11, #oncoloPTJP .onChar9, #orthopePTJP .onChar7 { font-size: 4.2rem; margin: 0 -.2em}
#vaccPTEN .onChar5, #vaccPTEN .onChar7, #vaccPTEN .onChar15 { width: 5px}

#anesthPTJP .onChar7 { font-size: 4.2rem; margin: 0 -.2em}
#anesthPTEn .onChar10, #anesthPTEn .onChar21, #spayPTEn .onChar9, #neuterPTEn .onChar11, #softPTEN .onChar9, #softPTEN .onChar16,
#orthopePTEN .onChar16, #orthopePTEN .onChar20, #discipPTEN .onChar15, #discipPTEN .onChar26 { width: 6px}

#discipPTJP .onChar5 { margin: 0 -.08em 0 -.15em} #discipPTJP .onChar6 { margin-right: -.04em}

/* Medical Page Common */
#medicalDepartment { max-width: calc(1440px - 5vw); margin: 50px auto 0; padding-right: 5vw; position: relative}

.MDWrapp { width: calc(78.25% - 70px)}
/* 「お悩みの飼い主様へ」背景色 */
.flexC:has(.MDWrapp[class*="PWBot"]) + #bottomBanner,
.flexC:has(.MDWrapp[id="Spay"]) + #bottomBanner,
.flexC:has(.MDWrapp[id="Neuter"]) + #bottomBanner,
.flexC:has(.MDWrapp[id="Oncology"]) + #bottomBanner{
  background-color: #e0f0ee;
  border-bottom: 2px solid #fff;
}

.BGWide { position: relative}
.BGWide::after { content: ''; position: absolute; top: 0; left: 0; background: #efefef; width: 30vw; height: 100%; margin-left: -29.9vw}

.MDPad { padding-left: 5vw}

.MDSign {
  background: #999; color: #fff; font-size: 1.2rem; text-align: center; letter-spacing: .08em;
  width: 90px; margin: 0; padding: 4px 0 3px; border-radius: 3px; display: inline-block}
.win .MDSign { padding: 3px 0 4px}

#MDPageTit { min-height: 86px; margin-top: 40px; padding: 4px 0 0 130px; position: relative}

.MDMark { position: absolute; top: 0; left: 0; width: 90px; height: 90px; border-radius: 5px; z-index: 1}
#Pulmonology .MDMark { background: #c2a0dd}
#Gastroenterology .MDMark { background: #faa769}
#Ophthalmology .MDMark { background: #d2c97e}
#Urology .MDMark { background: #d2ae4e}
#Dermatology .MDMark { background: #f295a7}
#Vaccination .MDMark { background: #57b577}
#Anesthesia .MDMark { background: #c799e9}
#Spay .MDMark { background: #f297c9}
#Neuter .MDMark { background: #69a9e9}
#Oncology .MDMark { background: #ae92d5}
#SoftTissue .MDMark { background: #5cb288}
#Orthopedics .MDMark { background: #6ea5f2}
#Discipline .MDMark { background: #b7827d}
#Dentistry .MDMark { background: #eea0d0}
#Radiology .MDMark { background: #9ea7ae}


.MDMark::after {
  content: ''; position: absolute; top: 50%; left: 50%;
  -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%); display: block}

#pulmonoMark::after { background: url(../images/medical/pulmono_sign.svg) no-repeat 0 0 / cover; width: 34px; height: 33px}
#gastroMark::after { background: url(../images/medical/gastro_sign.svg) no-repeat 0 0 / cover; width: 34px; height: 46px}
#ophtMark::after { background: url(../images/medical/opht_sign.svg) no-repeat 0 0 / cover; width: 36px; height: 24px}
#urologyMark::after { background: url(../images/medical/urology_sign.svg) no-repeat 0 0 / cover; width: 40px; height: 34px}
#dermatoMark::after { background: url(../images/medical/dermato_sign.svg) no-repeat 0 0 / cover; width: 36px; height: 26px}
#vaccinatMark::after { background: url(../images/medical/vaccinat_sign.svg) no-repeat 0 0 / cover; width: 34px; height: 34px}
#anesthMark::after { background: url(../images/medical/anesth_sign.svg) no-repeat 0 0 / cover; width: 28px; height: 38px}
#spayMark::after, #neuterMark::after {
  background: url(../images/medical/spay_sign.svg) no-repeat 0 0 / cover; width: 33px; height: 36px}
#oncoloMark::after { background: url(../images/medical/oncology_sign.svg) no-repeat 0 0 / cover; width: 36px; height: 36px}
#softMark::after { background: url(../images/medical/softtissue_sign.svg) no-repeat 0 0 / cover; width: 32px; height: 36px}
#orthopeMark::after { background: url(../images/medical/orthopedics_sign.svg) no-repeat 0 0 / cover; width: 36px; height: 36px}
#discipMark::after { background: url(../images/medical/discipline_sign.svg) no-repeat 0 0 / cover; width: 34px; height: 34px}
#dentalMark::after { background: url(../images/medical/dentistry_sign.svg) no-repeat 0 0 / cover; width: 40px; height: 33px}
#radioMark::after { background: url(../images/medical/radio_sign.svg) no-repeat 0 0 / cover; width: 36px; height: 36px}

/* Medical Page Cotents */
.MDContWrapp01 { padding: 70px 5vw}
.MDContWrapp02 { padding: 70px 0 0 5vw}

.MDHead { margin-top: 70px}

.MDPHInfo { line-height: 2.2; max-width: 720px}

.MDPHINotice { font-size: 1.5rem; display: block}
.MDPHINotice::before { content: '*'; color: #f02e72; font-size: 2rem; margin-right: 3px; vertical-align: -7px}

.MDCST { color: #177e52; font-size: 2.9rem; letter-spacing: .06em; margin: 0}

.MDCKind { font-size: 1.8rem; letter-spacing: .075em; margin: 40px 0 0; padding-left: 40px}

.MDSTSign { overflow: hidden; margin-right: 7px; display: inline-block; overflow: visible}
.MDSPulmono { background: url(../images/medical/pulmono_ico.svg); width: 28px; height: 28px; margin: 0 10px -3px 0}
.MDSGastro { background: url(../images/medical/gastro_ico.svg); width: 20px; height: 28px; margin-bottom: -4px}
.MDSOpht { background: url(../images/medical/opht_ico.svg); width: 30px; height: 20px; margin-bottom: -2px}
.MDurology { background: url(../images/medical/urology_ico.svg); width: 30px; height: 26px; margin-bottom: -4px}
.MDDermato { background: url(../images/medical/dermato_ico.svg); width: 30px; height: 21px}
.MDVaccinat { background: url(../images/medical/vaccinat_ico.svg); width: 30px; height: 30px; margin-bottom: -4px}
.MDAnesth { background: url(../images/medical/anesth_ico.svg); width: 22px; height: 30px; margin-bottom: -5px}
.MDSpayIco { background: url(../images/medical/spay_icon.svg); width: 28px; height: 30px; margin-bottom: -1px}
.MDNeuterIco { background: url(../images/medical/neuter_icon.svg); width: 28px; height: 30px; margin-bottom: -1px}
.MDSOncolo { background: url(../images/medical/oncology_ico.svg); width: 28px; height: 28px; margin-bottom: -4px}
.MDSSoft { background: url(../images/medical/softtissue_ico.svg); width: 26px; height: 30px; margin: 0 10px -5px 0}
.MDSOrthope { background: url(../images/medical/orthopedics_ico.svg); width: 28px; height: 28px; margin-bottom: -4px}
.MDSDiscip { background: url(../images/medical/discipline_ico.svg); width: 28px; height: 28px; margin: 0 9px -4px 0}
.MDSDental { background: url(../images/medical/dentistry_ico.svg); width: 30px; height: 25px; margin-bottom: -1px}
.MDSRadio { background: url(../images/medical/radio_ico.svg); width: 28px; height: 28px; margin: 0 12px -4px 0}

.medicalInfo { align-items: center; background: #fff; margin-top: 40px; padding: 20px 25px; border: 2px solid #f7ccb9; border-radius: 9px}

.medInfoCopy {
  font-size: 1.5rem; line-height: 1.8; letter-spacing: .06em; width: calc(100% - 80px); margin: 0}

.medInfoIco { background: url(../images/medical/info_sign02.svg) no-repeat 0 0 / cover; width: 60px; height: 60px; display: block}

.majorDiseases { margin-top: 50px}

.MDiseaseName, .MDListST, .MDMarked {
  font-size: 2rem; letter-spacing: .05em; margin: 0; padding-bottom: 12px; border-bottom: 1px solid #aeaeae; position: relative}
.MDiseaseName, .MDMarked { padding-left: 18px}
.MDListST, .MDMarked { margin-top: 45px}

.MDiseaseName rt { font-size: 9px; font-weight: 400; padding-bottom: 2px}

.MDLBorderlessST { font-size: 2rem; letter-spacing: .05em; margin: 45px 0 0}

.MDiseaseName::before, .MDMarked::before {
  content: ''; position: absolute; top: 2px; left: 0; background: #72c09e; width: 9px; height: 17px; display: block}
.MDiseaseName::before { top: 4px; height: 30px;}
.MDDetail { margin-top: 35px}

.safari.ios .MDiseaseName rt, .safari.mac .MDiseaseName rt { margin-bottom: -4px; padding: 0}
.safari.ios .MDiseaseName::before, .safari.mac .MDiseaseName::before { top: 3px}

.MDDKind {
  color: #fff; background: #5e9980; font-size: 1.5rem; text-align: center; letter-spacing: .075em;
  width: 90px; height: 23px; margin: 0; padding: 7px 0 0}

.MDDExp, .MDListCopy, .MDWICopy, .MDWICopy02, .MDNoICopy, .MDLBlessCopy, .MDCLItem {
  font-size: 1.5rem; line-height: 2; letter-spacing: .075em}
.MDDExp { width: calc(100% - 120px); margin: 0}
.MDListCopy { margin: 25px 0 0}
.MDLBlessCopy { margin: 20px 0 0}

.MDDNotice { color: #666; font-size: 1.5rem}
.MDDNotice::before { content: '*'; color: #f0337e; font-size: 2rem; margin-right: 4px; vertical-align: -7px}

.MDLTNum { color: #65a79e; font-size: 2.8rem; font-style: normal; letter-spacing: .02em; margin-right: 4px; vertical-align: -1px}

.MDwithImage { margin-top: 25px}
.MDWICopy { margin: 25px 0 0}
.MDWICopy02 { width: calc(100% - 300px); margin-block: 0}
.MDWImage { width: 270px; height: 180px}
.MDNoICopy { margin: 25px 0 0}

.medICcaution { color: #855a2e}
.MDICBorder { line-height: 2.2; padding-bottom: 2px; display: inline; border-bottom: 2px solid #ee1e2e}

.MDCList { margin:  0; padding: 0 0 0 2em}
.MDCLItem{
  position: relative;
  padding-left: 1.2em;
}
.MDCLItem::before { content: '●'; color: #c0ae99; font-size: 12px; margin-right: 3px; vertical-align: 1px; position: absolute; left: 0; top: .2em}

.reventionSchedule { width: 100%; margin: 50px auto 0}

.reventionScheList { width: 100%}
.reventionScheList img { width: 100%; height: auto}

.MDDLList { letter-spacing: .06em; margin: 0; padding: 10px 0 0 20px}

.DLDT { font-size: 1.6rem; margin: 25px 0 0; padding: 0 0 0 18px; position: relative}
.DLDT::before { content: '■'; position: absolute; top: 1px; left: 0; color: #b29e82; font-size: 1.4rem; margin-right: 4px}

.DLDD { font-size: 1.5rem; line-height: 1.8; margin: 1em 0 0; padding-left: 16px}

.caseImage, .caseImage02 { background: #eee; max-width: 650px; margin: 25px auto 0; padding: 25px 30px 25px; position: relative}

.caseIMST { color: #666; font-size: 1.7rem; line-height: 1; letter-spacing: .05em; width: 100%; margin: 0 0 15px; display: block}

.caseIM { width: 100%}
.caseImage img { width: 100%}

.icingIM { width: 230px}
.icingCopy { width: calc(100% - 260px); margin: 0}
#Dentistry .icingIM { width: 322px}

.caseIMName { color: #8e5e1e; font-size: 1.4rem; vertical-align: .045em}

.caseBefAft { font-size: 1.5rem; line-height: 1; letter-spacing: .05em; margin-top: 10px; display: block}

.caseImage::after {
  content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  background: #ccc; width: 38px; height: 46px; clip-path: polygon(0 0, 0% 100%, 100% 50%); margin-left: 3px; display: block}

.caseBAAfter { padding-top: 25px; display: block}

.DCLImage { justify-content: flex-start; margin: 30px 0 0 15px}
.DCLIM, .DCLIM03 { width: 40%; max-width: 270px; margin-right: 40px}
.DCLIM03 { width: calc(33.33% - 20px) !important; max-width: none !important; margin-right: 30px}
.DCLIM03:last-of-type { margin: 0}

.DCLIM img, .DCLIM03 img { width: 100%; height: auto}

.DCLDot { font-size: 1.3rem; letter-spacing: 0; margin-right: 1em}

/* Physician Introduction */
.physicianST, .supportSystemST { color: #0999a5; font-size: 2.6rem; letter-spacing: .04em; margin: 0}

.physicianIco { background: url(../images/medical/physician_icon.svg);
  width: 28px; height: 34px; margin: 0 10px -6px 0; display: inline-block}

.physicianIntroduction, .advisorIntroduction { align-items: center; width: 100%; margin-top: 30px; padding: 45px 0; position: relative; z-index: 1}
.physicianIntroduction:first-of-type { margin-top: 50px}
.advisorIntroduction { align-items: flex-start}

.physicianPhoto { width: 250px; -webkit-box-shadow: 1px -1px 0 0 rgba(0,0,0,.25); box-shadow: 1px -1px 0 0 rgba(0,0,0,.25)}
.advisorIntroduction .physicianPhoto { margin-top: 5px}
.physicianPhoto img {
  height: auto;
}

.doctorInCharge { width: calc(100% - 315px)}

.DICName { font-size: 2rem; letter-spacing: .1em; margin: 0}

.DICNEn { color: #7e7e7e; font-size: 1.4rem; font-style: normal; letter-spacing: .08em; margin-left: 15px}

.PIDetail { letter-spacing: .06em; margin: 35px 0 0; padding-right: 45px}

.PIDKind { font-size: 1.5rem; margin: 24px 0 0}
.PIDItem, .PIDItem02 { font-size: 1.4rem; margin: 12px 0 0 1em}
.PIDItem02 { margin-top: 9px}

.PIDISent { line-height: 1.8} .PIDISent02 { line-height: 1.4}

.PIDPeriod { width: 7.8em; display: inline-block}

.PIPBG { position: absolute; top: 0; right: 0; background: #f2f2f2; width: calc(100% - 125px); height: 100%; display: block; z-index: -1}

/* Support System */
.supportSystemST { color: #cc527e; margin-top: 70px}

.supportSIco { background: url(../images/medical/support_ico.svg);
  width: 30px; height: 28px; margin: 0 10px -5px 0; display: inline-block}

.supportSInfo { padding-left: 125px}

.advisorName { color: #cc527d; letter-spacing: 0; margin-right: 12px}

.advisorMemo { margin-top: 40px}

.AMemo { width: 100px}

.AMemoName {
  background: #888; color: #fff; font-size: 1.4rem;
  text-align: center; letter-spacing: .08em; text-indent: .04em; margin: 0; padding: 6px 0}

.AMemoInfo { width: calc(100% - 125px)}

.AMemoST { font-size: 1.8rem;letter-spacing: .06em; margin: 6px 0 0}

/* Anesthesia */
#anesthesiaRisks { width: 534px; height: 246px; margin: 30px auto 0; padding-bottom: 45px}

.anesthRiskST { color: #855a2e; padding-bottom: 25px}

.surgeryTimeZone {
  background: #5e997e; color: #fff; font-size: 1.9rem; letter-spacing: .1em; text-indent: .05em;
  margin: 45px 0 0; padding: 7px 15px 8px; display: inline-block}

.surgeryFlow { margin: 0; padding-left: 30px}

.SFlowProcess { font-size: 2rem; letter-spacing: .06em; margin: 45px 0 0}

.SFlowGuide { font-size: 1.5rem; letter-spacing: .06em; line-height: 2; margin: 20px 0 0}

/* Spay and Neuter Surgery */
#Spay, #Neuter { padding-bottom: 70px}

.spayBenefitsCautions { padding: 40px 0 0 30px}

.spayBCKind {  background: #5e997e; color: #fff; font-size: 1.7rem; text-align: center; width: 80px;
  margin: 30px 0 0; padding: 7px 0 8px; display: inline-block}

.spayBCList { margin: 25px 0 0; padding: 0 0 0 20px}

.spayBeneItem, .spayCautItem, .spayPriceItem {
  font-size: 1.6rem; line-height: 1.8; letter-spacing: .06em; margin: 10px 0; padding-left: 30px; position: relative}
.spayPriceItem { padding: 0}

.spayPrice { color: #855a2e}

.spayPNotice { color: #666; font-size: 1.4rem; line-height: 1.4; letter-spacing: .06em; margin-left: 15px}
.spayPNotice::before {content: '*'; color: #f00049; font-size: 2rem; margin-right: 4px; vertical-align: -.33em}

.spayBeneItem::before {
  content: ''; position: absolute; top: 10px; left: 5px; width: 14px; height: 5px;
  border-left: 3px solid #22b373; border-bottom: 3px solid #22b373; -webkit-transform: rotate(-45deg); transform: rotate(-45deg)}

.spayCautItem::after {
  content: 'i'; position: absolute; top: -2px; left: 8px; color: #f03e00; font-size: 18px; font-weight: 800;
  -webkit-transform:scaleX(1.1); transform:scaleX(1.1); z-index: 2}

.spayCautItem::before {
  content: ''; position: absolute; top: 3px; left: 0; background: #fff; width: 20px; height: 20px;
  border-radius: 50%; border: 1px solid #f03e00; z-index: 0}

#SFAnesthBT { line-height: 1.8}

#SFAnesthBT .TNLBB { padding: 12px 55px 12px 25px}
.win #SFAnesthBT .TNLBB { padding: 11px 55px 13px 25px}

/* Radiology */
.detectableCasesST { font-size: 1.8rem; letter-spacing: .05em; margin: 30px 0 0; padding: 0 0 8px 15px; position: relative}
.detectableCasesST::before {
  content: ''; position: absolute; top: 4px; left: 0; background: #72c09e; width: 8px; height: 13px; display: block}

.detectableCasesList { margin: 0; padding: 0 0 0 14px}

.DCLItem { font-size: 1.5rem; line-height: 1.8; letter-spacing: .05em; margin: 12px 0 0; padding-left: 15px}
.DCLItem::before { content: '●'; color: #b29977; font-size: 1rem; margin-right: 5px; margin-left: -14px; vertical-align: 12%}

/* Medical Page Side Bar */
.MDSideBar { width: 21.75%; min-width: 235px; padding-bottom: 1000px}

.MDSFixed { position: sticky; top: 0}
.fixed .MDSFixed { padding-top: 90px}

.MDSCat { background: #e0f0ee; font-size: 1.7rem; letter-spacing: .075em; margin: 0; padding: 15px}
.MDSCat:nth-of-type(2), .MDSCat:nth-of-type(3) { margin-top: 50px}

.MDSList { margin: 10px 0 0; padding: 0}

.MDSItem { font-size: 1.6rem; letter-spacing: .05em; margin: 0}

.MDSLink {
  color: #444; text-decoration: none; padding: 15px; border-bottom: 1px solid #ddd; display: block;
  position: relative; overflow: hidden; cursor: pointer}
.MDSLink:hover { color: #008299}

.MDSLink::before {
  content: ''; position: absolute; top: 0; left: auto; right: 0;
  background: #f2faff; width: 0; height: 100%; display: block; z-index: -1}

.MDSLink:hover::before { left: 0; right: auto; width: 100%}


/* -------------------------------------------
  SYMPTOM
------------------------------------------- */
#symTitEn .onChar8, #symTitEn .onChar13 { width: 8px}

#symptomHeadCopy {
  background: rgba(255,255,255,.8); font-size: 1.6rem; line-height: 2.2; letter-spacing: .06em;
  width: 46%; min-width: 500px; max-width: 600px; margin: 90px 0 0; padding: 16px 18px 16px 0}

.symptomHCNotice { margin-top: 12px; display: block}

/* Symptom Navi */
#symptomNav { margin-top: 20px}

.symNavList { margin: 0; padding: 0}

.symNavItem { flex-grow: 1; font-size: 1.6rem; text-align: center; letter-spacing: .05em; width: auto; margin: 0 2px}
.symNavItem:first-of-type { margin-left: 0}
.symNavItem:last-of-type { margin-right: 0}

.symNavLink {
  color: #444; text-decoration: none; padding: 12px 20px 18px; display: block;
  position: relative; z-index: 1; cursor: pointer; overflow: hidden}
.symNavLink:hover { color: #fff}

.symNavLink::before, .symNavLink::after { content: ''; position: absolute; top: 0; height: 100%; display: block}
.symNavLink::before { left: auto; right: 0; width: 100%; background: #eae5d9; z-index: -2}
.symNavLink::after { left: 0; right: auto; width: 0; background: #52c0c9; z-index: -1}

.SNLSign {
  position: absolute; bottom: 7px; left: 50%; background: #b29977; width: 8px; height: 6px; margin-left: -4px;
  clip-path: polygon(0 0, 50% 100%, 100% 0); display: block}
.symNavLink:hover .SNLSign { background: #fff962; bottom: 5px}

.symNavLink:hover::after { width: 100%}

.symNavItem:first-of-type .symNavLink { border-radius: 5px 0 0 5px}
.symNavItem:last-of-type .symNavLink { border-radius: 0 5px 5px 0}

/* Symptom List */
#symptomList { padding: 30px 0 80px}

.symptomItem { margin-top: 40px}

.symptomkind { color: #005e7e; background: #dee; font-size: 1.8rem; letter-spacing: .1em; margin: 0; padding: 10px 20px}

.symptomDetail { align-items: stretch; margin: 5px 0 0}

.symDT, .symDD, .PDDT, .PDDD { font-size: 1.6rem; line-height: 1.6; letter-spacing: .06em; margin: 0 0 5px; padding: 15px 20px; display: block}
.symDT, .PDDT { color: #4e4e4e; width: calc(30% - 40px)}
.symDD, .PDDD { display: flex; align-items: center; width: calc(100% - 30% - 45px)}
.symDT { background: #f0f0f0}
.symDD { background: #f9f0e8}

.DDUrgent { color: #d25e00; font-size: 1.7rem; font-weight: 600}

.DDNotice { color: #855939; font-size: 1.5rem; font-weight: 500; width: 100%; display: block}
.DDNotice::before { content: "*"; color: #e53e66; font-size: 1.7rem; vertical-align: -17%; margin-right: 3px}

.possibleDiseases { align-items: stretch; margin: 0}

.PDDT, .PDDD { padding: 10px 20px 15px}
.PDDT { padding-right: 15px; border-left: 1px solid #c7d2d5; border-bottom: 2px solid #c7d2d5}
.PDDD { line-height: 1.8; border-left: 1px solid #f0d2b9; border-bottom: 2px solid #f0d2b9}


/* -------------------------------------------
  Access
------------------------------------------- */
#ACCHeadCopy { line-height: 2.2}

.accessMapWrapp { width: calc(100% - 4px); margin-top: 80px; padding: 1px; border: 1px solid #bbb}

#AccMap { width: calc(100% - 2px); height: 516px; border: 1px solid #fff}

.AMapInfo { align-items: center; padding: 40px 0}

.AMAddress { margin: 0; padding-left: 20px; position: relative}

.AMAddress::before {
  content: ''; position: absolute; top: 5px; left: 0;
  background: url(../images/access/pin.svg) no-repeat 0 0 / cover; width: 13px; height: 19px; display: block}

.AMapBT { letter-spacing: .1em; margin: 0}

/* By The Car */
.accTransportation { padding-bottom: 50px}

.accTransportST { padding-top: 50px; border-top: 2px solid #ddd}

.BCarInfo { line-height: 2.2; margin: 30px 0 0}

.BCarMap { width: calc(50% - 30px)}

.BCMName { font-size: 1.8rem; letter-spacing: .1em; margin: 0}

.BCMAdd { line-height: 1; margin: 12px 0 0}

.BCGMWrapp { width: calc(100% - 4px); margin-top: 30px; padding: 1px; border: 1px solid #bbb}

.BCGMap { width: calc(100% - 2px); height: 396px; border: 1px solid #fff}

/* Access Opening Hour */
#accOHour { padding: 70px 5vw 65px}

#accOHST { color: #f96600; font-size: 3.8rem; letter-spacing: .04em; margin: 0}
.AOHSEN { color: #444; font-size: 1.8rem; font-style: normal; margin-top: 12px; display: block}

.AOHCal { align-items: center; margin: 0 auto; padding: 10px 70px 0}

#AOHCalender { width: 55%; min-width: 480px}

.AOHCInfo { width: calc(45% - 65px)}

.AOHCNotice { font-size: 1.4rem; line-height: 2; letter-spacing: .075em; margin: 0}

#AOHCBT { letter-spacing: .075em; font-size: 1.5rem; margin: 5px 0 0; z-index: 1; position: relative}

#AOHCBT .TNLBB { padding: 15px 65px 15px 30px}
.win #AOHCBT .TNLBB { padding: 15px 65px 16px 30px}

/* -------------------------------------------
  Column
------------------------------------------- */
/* Column List */
#columnEN .onChar12 { width: 8px}

#columnHeadCopy { font-size: 2rem; line-height: 2; letter-spacing: .06em; margin: 9vw 0 0}

.columnWrapp, .columnListHead, .columnPostHead { max-width: 1340px; margin: 80px auto 0; padding: 50px 5vw; position: relative}
.columnListHead { padding: 0 5vw 30px}
.columnPostHead { padding: 10px 5vw}

.articleList { width: calc(100% - 340px)}

.ALLink {
  text-decoration: none; width: calc(100% - 40px); margin-top: 30px; display: block;
  position: relative; z-index: 1; cursor: pointer; overflow: hidden}
.ALLink:first-of-type { margin: 0}

.ALLink::before, .ALLink::after {
  content: ''; position: absolute; top: 0; left: 0; height: 100%}
.ALLink::before { background: #fff; width: 100%; z-index: -2}
.ALLink::after { left: auto; right: 0; background: #a9e7ea; width: 0; z-index: -1}
.ALLink:hover::after { left: 0; right: auto; width: 100%}

.ALItem { align-items: center; padding: 20px; position: relative}

.ALThumb, .noImage { width: 40%; margin: 0; opacity: 1; overflow: hidden}
.ALThumb img, .noImage { min-height: 200px; object-fit: cover}
.noImage { background: #c0d9a2; position: relative; z-index: 1}
.noImage::after {
 content: ''; position: absolute; top: 50%; left: 50%;
 background: url(../images/column/image_ico.svg) no-repeat 0 0 / 60px;
 width: 60px; height: 60px; margin: -30px 0 0 -30px; display: block; z-index: 2}

.ALLink:hover .ALThumb { opacity: .7; -webkit-transform: translateY(-2px); transform: translateY(-2px)}
.ALLink:hover .ALThumb img { -webkit-transform: scale(1.06); transform: scale(1.06)}

.ALData { width: calc(100% - 47.5%); padding-right: 20px}

.ALTitle { color: #444; font-size: 1.8rem; line-height: 1.5; letter-spacing: .05em; min-height: 3em; margin: 0}
.ALCopy {
  color: #555; font-size: 1.4rem; line-height: 1.8; margin: 15px 0 0; display: -webkit-box;
  -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-clamp: 3; overflow: hidden;
}
.ALTime { color: #777; font-size: 1.5rem; letter-spacing: .1em; margin-top: 15px; display: block}

.ALSign {
  position: absolute; bottom: 30px; right: 30px;
  background: #b5b5b5; width: 24px; height: 24px; border-radius: 50%; display: block}
.ALLink:hover .ALSign { background: #00a9b2; width: 28px; height: 28px; margin: -2px -2px 0 0}

.ALSign::before, .ALSign::after { content: ''; position: absolute; background: #fff; height: 2px}
.ALSign::before { top: 50%; left: 6px; width: 12px; margin-top: -1px}
.ALSign::after { top: 9px; right: 7px; width: 3px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}
.ALLink:hover .ALSign::before { left: 8px}
.ALLink:hover .ALSign::after { top: 11px; right: 9px}

/* Column List Page */
.CLHTitle { font-size: 5.2rem; letter-spacing: .05em; margin: 0}

.CLHKind { font-size: 1.6rem; font-style: normal; letter-spacing: .06em; margin-bottom: 15px; display: block}

.CLHTSub { font-size: 2.5rem; margin-left: 5px; vertical-align: -.15em}

.CLHColumn { background: #888; text-align: center; width: 260px; height: 80px; margin: 0; border-radius: 3px; position: relative}

.CLHCST, .CLHCEN { position: absolute; left: 0; width: 100%}
.CLHCST { top: 18px; color: #fff; font-size: 2.2rem; letter-spacing: .05em}
.CLHCEN { bottom: 18px; color: #fdcdab; font-size: 1.4rem; letter-spacing: .1em}

/* Column Alticle Page */
.CPHST { font-size: 2rem; letter-spacing: .06em; margin: 0; padding-bottom: 10px; display: inline-block; border-bottom: 2px solid #ddd}

.CPHEN { color: #f96600; font-size: 1.6rem; margin-left: 12px; vertical-align: -1px}

.columnAlticle { width: calc(100% - 460px); padding: 60px}

.columnAlticle { background: #fff}

.columnTitle { color: #444; font-size: 2.8rem; letter-spacing: .1em; line-height: 1.3; margin: 0; position: relative}

.columnMeta { display: flex; flex-flow: row; justify-content: flex-start}

.NTitMark {
  position: absolute; top: 0; left: 50%; background: url(../images/news/news_ico.svg) no-repeat 0 0 / 36px 36px;
  width: 36px; height: 36px; margin-left: -18px; display: block}

.columnTime, .columnCat { color: #888; font-size: 1.5rem; letter-spacing: .1em; margin: 20px 0 0; display: block}
.columnCat { letter-spacing: .06em; margin-left: 20px}

.colCatLink {
  color: #333; text-decoration: none; margin-left: .5em; padding-bottom: 4px; border-bottom: 1px solid #7eaebb;
  display: inline-block; position: relative}
.colCatLink:hover { color: #39b; border-bottom: 1px solid #e57e2e}

.CHKeyList { justify-content: flex-start; margin: 0; padding: 15px 0 0}

.CHKeyList .keyItem { margin: 0 15px 0 0}


/* CMS Article Body */
#columnBody { margin: 40px auto 0; padding-top: 35px; border-top: 1px solid #ccc}

.newsBody p, .newsBody li { font-size: 1.6rem; line-height: 2.2; letter-spacing: .06em; margin: 1.25em 0 0}
.newsBody h2, .newsBody h3, .newsBody h4, .newsBody h5 { color: #494949; line-height: 1.8; letter-spacing: .075em; margin: 1.5em 0}
.newsBody h2 { font-size: 2.4rem; margin: 1.5em 0; padding-bottom: 10px; border-bottom: 2px solid #ddd; display: inline-block}
.newsBody h3 { font-size: 2.2rem}
.newsBody h4 { font-size: 1.9rem; margin-bottom: 1.1em}
.newsBody h5 { font-size: 1.8rem; margin-bottom: 1.1em}
.newsBody ul { margin: 0; padding: 0 0 0 3.8em}
.newsBody li { margin: 0; list-style-type: circle}
.newsBody ol li { list-style-type: decimal }
.newsBody hr { margin: 3em 0; border-top: 1px solid #ccc }

.newsBody figure{ margin: 1.5em 0 }
.newsBody img { width: auto !important; max-width: 100%; height: auto !important; margin: 0 auto; display: block}
.newsBody a img { text-decoration: none; border: none; outline: none}
.newsBody .wp-block-buttons{
  font-size: 1.6rem; line-height: 2.2; letter-spacing: .06em; margin: 1.25em 0 0;
}
.newsBody .wp-block-buttons a:hover{
  opacity: .8;
}
.newsBody :is(h2, h3, h4, h5) + :is(h3, h4, h5, p, figure, .wp-block-buttons) { margin-top: 0 }


/* Column Side Bar */
.columnSideBar { background: #fff; width: 240px; padding: 30px 20px; position: relative}

.CSideFixed { position: sticky; top: 0}

.CSBST { color: #555; font-size: 1.6rem; letter-spacing: .06em; margin: 0}

.CSNList { margin: 20px 0 0; padding: 0}

.CSNItem, .keyItem { font-size: 1.6rem; line-height: 1.5; letter-spacing: .06em}

.CSNLink, .keyLink { color: #444; text-decoration: none; display: block; position: relative; z-index: 1; cursor: pointer; overflow: hidden}
.CSNLink { padding: 12px 10px 10px 10px; border-bottom: 1px solid #bbb}
.CSNLink:hover { padding-left: 15px}

.CSKeyList { justify-content: flex-start; margin: 5px 0 0; padding: 0}

.keyItem { margin: 15px 7px; display: inline-block}

.keyLink { background: #e2e2e2; padding: 5px 12px; border-radius: 15px} .win .keyLink { padding: 4px 12px 5px}
.keyLink:hover { -webkit-transform: translate(1px,-1px); transform: translate(1px,-1px)}

.CSNLink::after, .keyLink::before, .keyLink::after {
  content: ''; position: absolute; top: 0; left: auto; right: 0; width: 0; height: 100%; display: block}
.keyLink::before { width: 100%; z-index: -2}

.CSNLink::after, .keyLink::after { background: #cbeff1; z-index: -1}
.keyLink::after{ width: 100%; transform: scale(0)}

.CSNLink:hover::after { left: 0; right: auto; width: 100%}

.keyLink:hover::after { -webkit-transform: scale(1); transform: scale(1)}


/* CMS List Navigation */
#paginationList { text-align: center; margin: 0 auto; padding: 30px 7px 50px 0; border-top: 2px solid #fff}

#paginationList li { font-size: 1.6rem; margin: 7px 0 0 7px; display: inline-block}

.link_page:not(.link_before):not(.link_next):not(.dots), .current_page { width: 40px; height: 40px; margin-top: 5px; display: block; position: relative; z-index: 1}

.link_page:not(.link_before):not(.link_next):not(.dots):before, .link_page:not(.link_before):not(.link_next):not(.dots):after, .current_page:before {
  content: ''; position: absolute; top: -11px; left: 0; width: 40px; height: 40px;
  -webkit-border-radius: 50%; border-radius: 50%}

#paginationList .link_page:not(.current_page):before { background: #399eb5; z-index: -2}
#paginationList .current_page:before { background: #b5b5b5; z-index: -1}

#paginationList .link_page:not(.current_page):after {
  background: #00c2cc; -webkit-transform: scale(0); transform: scale(0); z-index: -1}

#paginationList .link_page:not(.current_page):hover:before { opacity: 0}
#paginationList .link_page:not(.current_page):hover:after { -webkit-transform: scale(1); transform: scale(1)}

#paginationList a { color: #fff; text-decoration: none; cursor: pointer; display: block}

.current_page { color: #f9f9f9; }

#paginationList .link_before, #paginationList .link_next {
  color: #4799d5; font-size: 2.2rem; padding: 0 2px; vertical-align: -.15em; display: inline-block}
.win #paginationList .link_before, .win #paginationList .link_next { -webkit-transform: scaleY(1.4); transform: scaleY(1.4)}
#paginationList .link_before:hover, #paginationList .link_next:hover { color: #00c2cc}
#paginationList .link_before.disabled, #paginationList .link_next.disabled, #paginationList .dots {
  color: #b5b5b5;
}


/* Individual Pagination */
#newsIndNavi, #blogIndNavi { margin: 0 auto; padding: 0 0 2px; position: relative}

.win .indPageNavi { font-weight: 500}

.indPageNavi a, .indPageNavi li > span {
 color: #555; font-size: 1.5rem; text-align: center; letter-spacing: .1em; text-decoration: none;
 padding: 52px 0 53px; display: block; position: relative; z-index: 1}
.win.firefox .indPageNavi a, .win.firefox .indPageNavi li > span { padding: 51px 0 54px}
.indPageNavi li > span.disabled{
  opacity: .5;
}

#newsIndNavi.indPageNavi a:hover, #blogIndNavi.indPageNavi a:hover { color: #fff; text-shadow: none}

.previousEntry, .nextEntry { letter-spacing: .06em; width: calc(33.5% - 2px)}
.previousEntry { border-right: 2px solid #fff}
.nextEntry { border-left: 2px solid #fff}
.returnList { letter-spacing: .2em; width: 33%}
.returnList .spFalse { margin-right: 10px}

.previousEntry a:before, .returnList a:before, .nextEntry a:before,
.previousEntry a:after, .returnList a:after, .nextEntry a:after,
.previousEntry > span:before, .nextEntry > span:before,
.previousEntry > span:after, .nextEntry > span:after {
 content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: block; z-index: -1}

#newsIndNavi .previousEntry a:before, #newsIndNavi .nextEntry a:before,
#newsIndNavi .previousEntry > span:before, #newsIndNavi .nextEntry > span:before { background: #e0e0e0}
#newsIndNavi .returnList a:before { background: #d2d2d2}

#blogIndNavi .previousEntry a:before, #blogIndNavi .nextEntry a:before,
#blogIndNavi .previousEntry > span:before, #blogIndNavi .nextEntry > span:before { background: #f2f0de}
#blogIndNavi .returnList a:before { background: #e2e2d5}

.previousEntry a:after, .returnList a:after, .nextEntry a:after,
.previousEntry > span:after, .nextEntry > span:after {
 background: #66b5c0; -webkit-transform: scaleX(0); transform: scaleX(0)}
.returnList a:after { background: #888}

#blogIndNavi .previousEntry a:after, #blogIndNavi .nextEntry a:after,
#blogIndNavi .previousEntry > span:after, #blogIndNavi .nextEntry > span:after { background: #b9b29e}
#blogIndNavi .returnList a:after { background: #999582}

.previousEntry a:after, .previousEntry > span:after { -webkit-transform-origin: top right; transform-origin: top right}
.returnList a:after { -webkit-transform-origin: 50%; transform-origin: 50%}
.nextEntry a:after, .nextEntry > span:after { -webkit-transform-origin: top left; transform-origin: top left}

.previousEntry a:hover:after, .returnList a:hover:after, .nextEntry a:hover:after {
 -webkit-transform: scaleX(1); transform: scaleX(1)}

/* Pagination Link Sign */
.RLSign, .PESign, .NESign { position: absolute; top: 50%; background: #444; height: 1px; transition: inherit; pointer-events: none}

.RLSign { top: inherit; bottom: 30px; left: calc(50% - 20px); background: #555; width: 50px}
.PESign { top: calc(50% + 1px); left: 20%; background: #555; width: 30px}
.NESign { top: calc(50% + 1px); right: 20%; background: #555; width: 30px}

.PLSign:before, .NESign:before {
  content: ''; position: absolute; right: 0; bottom: 0; transition: inherit;
  border-top: 2px solid transparent; border-right: 5px solid transparent;
  border-left: 3px solid #555; border-bottom: 4px solid #555}

.PESign:before, .returnList a i:before {
  content: ''; position: absolute; left: 0; bottom: 0; transition: inherit; border-top: 1px solid transparent;
  border-left: 6px solid transparent; border-right: 3px solid #555; border-bottom: 4px solid #555}
.NESign:before { border-left: 3px solid #555; border-bottom: 4px solid #555}

.returnList a .RLSign:before {
  content: ''; position: absolute; bottom: 10px; left: 22px; transition: inherit; border-top: 1px solid transparent;
  border-left: 6px solid transparent; border-right: 3px solid #555; border-bottom: 4px solid #555}
.returnList a .RLSign:after {
  content: ''; position: absolute; bottom: 0;right: 0; width: 18px; height: 10px;
  border-top: 1px solid #555; border-right: 1px solid #555; transition: inherit; }

a:hover .PESign { left: 16%; background: #fff}
a:hover .PESign:before { border-right: 3px solid #fff; border-bottom: 4px solid #fff}
a:hover .NESign { right: 16%; background: #fff}
a:hover .NESign:before { border-left: 3px solid #fff; border-bottom: 4px solid #fff}

.returnList a:hover i { left: 50%; background: #fff; width: 20px}
.returnList a:hover i:before {
    left: -15px; border-right: 3px solid #fff; border-bottom: 4px solid #fff}
.returnList a:hover i:after { width: 28px; border-color: #fff}


/* -------------------------------------------
  News
------------------------------------------- */
/* News List */
#newsPageTitle { margin: 0}

#newsHeadCopy { font-size: 2rem; letter-spacing: .06em; margin: 60px 0 0}

.newsList { max-width: 1080px; margin: 0 auto; padding: 100px 5vw 20px}

.NLLink {
  text-decoration: none; padding: 20px; border-top: 2px solid #ccc;
  display: block; position: relative; z-index: 1; cursor: pointer; overflow: hidden}
.NLLink:last-of-type { border-bottom: 2px solid #ccc}

.NLLink::after {
  content: ''; position: absolute; top: 0; left: auto; right: 0; background: #a9e7ea; width: 0; height: 100%; display: block; z-index: -1}
.NLLink:hover::after { left: 0; right: auto; width: 100%}

.NLItem { -webkit-justify-content: flex-start; justify-content: flex-start; align-items: center}

.NLImage { width: 220px}
.NLTitle {
  color: #333; font-size: 1.8rem; text-shadow: 1px 1px 0 rgba(255,255,255,.5);
  line-height: 1.8; letter-spacing: .06em; width: calc(100% - 380px); margin: 0; padding: 15px 0 15px 50px}
.NLTime { color: #7e7e7e; font-size: 1.5rem; letter-spacing: .1em; margin-top: 30px; display: block}
.NLLink:hover .NLTitle { -webkit-transform: translateX(5px); transform: translateX(5px)}

.NLImage img, .NLNoImage { height: 154px; object-fit: cover}
.NLNoImage { background: #ccc; position: relative; z-index: 1}
.NLNoImage::after {
 content: ''; position: absolute; top: 50%; left: 50%;
 background: url(../images/column/image_ico.svg) no-repeat 0 0 / 60px;
 width: 60px; height: 60px; margin: -30px 0 0 -30px; display: block; z-index: 2}
 .NLLink:hover .NLNoImage { background-color: #a7ccb2}

 .NLLink:hover img, .NLLink:hover .NLNoImage::after { -webkit-transform: scale(1.05); transform: scale(1.05)}


/* News Post */
#newsIndTitle { letter-spacing: .05em; margin: 0}

#newsIndTJP { color: #555; font-size: 3rem; letter-spacing: .04em; display: block}

#newsIndTEN { color: #f96600; font-size: 1.8rem; letter-spacing: .06em; margin: 10px 0 0 1px; display: block}

#newsPost { max-width: 960px; margin: 50px auto 0; padding-bottom: 70px}

.newsTitle { font-size: 2.8rem; line-height: 1.6; letter-spacing: .05em; margin: 0; padding-bottom: 15px; border-bottom: 1px solid #bbb}

.newsTime { color: #777; font-size: 1.5rem; letter-spacing: .08em; margin-top: 12px; display: block}

#NPBody { padding-top: 30px}

#NPBody img { max-width: 900px; margin: 0 auto; padding: 10px 0}

#NPBody .wp-block-table img { max-width: 100%; }


/* -------------------------------------------
  Forvets
------------------------------------------- */
.BGGray#forvetsAbout .innerWrapp + .innerWrapp{
  border-top: 3px solid #FFF;
}
.FVsp{
  display: none;
}
.FVCopy{
  margin: 0;
}
.FVTit{
  font-size: 2.4rem;
  font-weight: 700;
  margin: 0;
}
.FVPMark{
  display: flex;
}
.FVPMark .FVPMarkTxt{
  flex: 1
}
.FVBT{
  margin: 0;
}
.FVBT.flexC{
  justify-content: flex-start;
  gap: 18px 25px;
}
.LBLabel{
  border-radius: 3px;
  background: #FFF;
  color: #17798e;
  font-size: 1em;
  font-weight: 700;
  line-height: 1;
  padding: 0.25em .35em;
  margin: 0 0 0 18px;
}
.AUList{
  gap: 23px 55px;
}
.AUItem{
  background-color: #FFF;
  width: calc(50% - (55px / 2));
}
.AUItemText{
  display: flex;
  flex-direction: column;
  padding: 20px 28px 30px;
  flex: 1;
}
.AUTit{
  font-size: 1.6rem;
  margin: 0 0 15px;
}
.AUTxt{
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 5px;
}
.AUEn{
  color: #f96600;
  font-size: 1.4rem;
  font-weight: 700;
  font-family: "Figtree", "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  margin: 0 0 20px;
}
.AUItemText .FVBT{
  margin: auto 0 0;
}
.AUItemText .FVBT .LBB01{
  padding: 17px 45px 17px 15px;
}
.AUItemText .FVBT .LBB01 .LSign01{
  right: 15px;
}
.AUItemIM{
  overflow: hidden;
  height: 100%;
  width: 47.5%;
}
.AUItemIM img{
  height: 100%;
  width: 100%;
  object-fit: cover;
  display: block;
}
#forvetsLetters{
  padding-bottom: 0;
}
.formWrapp{
  background-color: #FFF;
  border-radius: 6px;
  padding: 40px 45px 80px;
  margin-top: 35px;
}
.wpcf7-form-control-wrap[data-name="pet-kind"] .wpcf7-list-item{
  min-width: 60px;
}
.wpcf7-form-control-wrap[data-name="request-details"] .wpcf7-form-control{
  display: grid;
  grid-template-columns: 220px 1fr;
}
.wpcf7-form-control-wrap[data-name="request-details"] .wpcf7-form-control .wpcf7-list-item{
  margin-right: 10px;
}
.wpcf7-form-control-wrap[data-name="pet-diagnose"] .wpcf7-form-control{
  display: grid;
  grid-template-columns: 260px 1fr;
}

/* -------------------------------------------
  Tab
------------------------------------------- */
.tabBtns{
  gap: 0 12px;
  justify-content: flex-start;
  padding: 0;
  margin: 0;
}
.tabBtn{
  cursor: pointer;
  padding: 6px;
}
.tabBtnInner{
  background-color: #b3b3b3;
  color: #FFF;
  display: block;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  padding: 10px 22px;
  text-align: center;
  transition: opacity .3s;
}
.tabBtn:hover .tabBtnInner{
  opacity: .8;
}
.is-active .tabBtnInner{
  background-color: #16798e;
}
.tabBtnG.is-active .tabBtnInner{
  background-color: #4ab05b;
}
.tabBtnB.is-active .tabBtnInner{
  background-color: #009dd9;
}
.tabContentsWrapp{
  padding: 50px 60px 60px;
}
.tabContents:not(.is-active){
  display: none;
}


/* -------------------------------------------
  Form
------------------------------------------- */
.formItem{
  display: block;
  margin-top: 15px;
}
.formItem p:not([class]){
  margin: 0;
}
.wpcf7-form-control-wrap + .wpcf7-form-control-wrap > input{
  margin-top: 8px;
}
.formLb{
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 5px;
}
.formItem:has(.wpcf7-list-item) .formLb{
  margin-bottom: 0;
}
.FormMR{
  background-color: #f96600;
  border-radius: 2px;
  color: #FFF;
  display: inline-block;
  font-size: .7em;
  font-weight: 700;
  margin: 0 0 .1em .5em;
  padding: .1em .5em;
  vertical-align: text-bottom;
}
/* form input */
.wpcf7 input:not(.wpcf7-submit), .wpcf7 select, .wpcf7 textarea{
  background-color: #FFF;
  border: 1px solid #b3b3b3;
  border-radius: 3px;
  box-sizing: border-box;
  font-size: 1.5rem;
  padding: 17px 20px;
}
.wpcf7 textarea{
  height: 192px;
}
.wpcf7 input:not(.wpcf7-submit).wpcf7-not-valid, .wpcf7 select.wpcf7-not-valid, .wpcf7 textarea.wpcf7-not-valid{
  border-color: #ee4853;
}
.wpcf7 select{
  -webkit-appearance: none;
  appearance: none;
  background: url(../images/recruit/ico_arrowBorder_down.svg) right 7px center / 9px auto no-repeat;
  padding: 16px 20px;
  min-width: 138px;
}
.inputFull{
  width: 100%;
}
.formSub{
  font-size: 1.5rem;
  margin: 0 8px;
}
.inputMgt{
  margin-top: 8px;
}
/* radio, checkboz */
.wpcf7-list-item{
  margin: 8px 35px 0 0;
}
.wpcf7-list-item label{
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1.5;
  box-sizing: border-box;
  position: relative;
  cursor: pointer;
  padding-left: 28px;
}
.wpcf7 label:has(input[type=radio]:disabled),
.wpcf7 label:has(input[type=checkbox]:disabled){
  opacity: 0.4;
}
.wpcf7 input[type=radio],
.wpcf7 input[type=checkbox]{
  appearance: none;
  background: #FFFFFF;
  border: 1px solid #4d4d4d;
  border-radius: 4px;
  box-sizing: border-box;
  width: 20px;
  height: 20px;
  padding: 0;
  margin: 0;
  box-shadow: 0 0 0 0 transparent;
  position: absolute;
  transform: translateY(-50%);
  top: 54%;
  left: 0;
}
.wpcf7 .radioAny input[type=checkbox],
.wpcf7 input[type=radio]{
  border-radius: 50%;
}
.wpcf7-not-valid input[type=radio],
.wpcf7-not-valid input[type=checkbox]{
  border-color: #ee4853;
}
.wpcf7 input[type=radio]::before,
.wpcf7 input[type=checkbox]::before{
  position: absolute;
  inset: 0;
  display: block;
  content: "";
  opacity: 0;
}
.wpcf7 .radioAny input[type=checkbox]::before,
.wpcf7 input[type=radio]::before{
  background: #0075ff;
  border-radius: 50%;
  height: 60%;
  width: 60%;
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
.wpcf7 .wpcf7-checkbox:not(.radioAny) input[type=checkbox]::before {
  width: 100%;
  height: 100%;
  mask-image: url("../images/common/icon_check.svg");
  mask-repeat: no-repeat;
  mask-size: contain;
  background-color: #FFFFFF;
}
.wpcf7 input[type=radio]:checked,
.wpcf7 input[type=checkbox]:checked{
  border-color: #0075ff;
  border-width: 2px;
}
.wpcf7 .wpcf7-checkbox:not(.radioAny) input[type=checkbox]:checked{
  background: #0075ff;
}
.wpcf7 input[type=radio]:checked::before,
.wpcf7 input[type=checkbox]:checked::before{
  opacity: 1;
}
/* file */
.wpcf7 input[type="file"]{
  border: none;
  color: #16798e;
  padding: 0;
  margin: 10px 0 0;
  width: 100%;
}
.wpcf7 input[type="file"]::file-selector-button{
  background: #16798e;
  border: none;
  border-radius: 3px;
  color: #FFF;
  padding: 12px 17px;
  margin-right: 5px;
}
/* error */
.wpcf7 .wpcf7-not-valid-tip,
.wpcf7 form .wpcf7-response-output,
.customErrorText{
  color: #ee4853;
  border: none;
  display: flex;
  align-items: center;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 6px;
  padding: 0;
  position: relative;
}
.wpcf7 form .wpcf7-response-output{
  background: #fef0f1;
  border-radius: 3px;
  box-sizing: border-box;
  justify-content: center;
  padding: 17px 10px;
  margin: 0 auto 50px;
  text-align: left;
  width: 100%;
}
.wpcf7 .wpcf7-not-valid-tip::before,
.wpcf7 form .wpcf7-response-output::before,
.customErrorText::before{
  content: "";
  display: block;
  flex-shrink: 0;
  background: url(../images/common/icon_caution.svg) center center / contain no-repeat;
  margin-right: .3em;
  height: 1.3em;
  width: 1.3em;
}
.wpcf7 form.sent .wpcf7-response-output{
  background: rgb(70, 180, 80, .3);
  color: #333;
  padding: 20px 10px;
  font-size: 1.5rem;
  font-weight: 500;
  width: 100%;
  text-align: center;
}
.wpcf7 form.sent .wpcf7-response-output::before{
  content: none;
}
.customError .wpcf7-not-valid-tip{
  display: none;
}
.customError:not(:has(.wpcf7-not-valid-tip)) .customErrorText{
  display: none;
}

.wpcf7 .wpcf7-response-output {
  margin:10px 0 0;
  padding:8px 35px 8px 14px;
  -webkit-border-radius:4px;
  -moz-border-radius:4px;
  border-radius:4px; }
/* button */
.wpcf7-spinner{
  visibility: hidden;
  display: none;
}
.formSubmit p{
  margin: 0;
  height: 100%;
  width: 100%;
  position: relative;
  z-index: 2;
}
.formSubmitWrapp{
  margin: 65px auto 0;
  text-align: center;
}
.formSubmit{
  display: inline-block;
  position: relative;
}
.formSubmit input.wpcf7-submit,
.formSubmit input.wpcf7-previous{
  border: none;
  background: none;
  cursor: pointer;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: 1.6rem;
  font-weight: 500;
  text-decoration: none;
  display: inline-block;
  z-index: 1;
  overflow: hidden;
  cursor: pointer;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 12px 65px 12px 30px;
  margin: 0;
}
.formSubmit::before,
.formSubmit::after{
  content: '';
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
}
.formSubmit::before{
  background: #f9851e;
  left: 0;
  width: 100%;
  z-index: 0;
}
.formSubmit::after{
  left: auto;
  right: 0;
  background: #00a9b2;
  width: 0;
  z-index: 1;
  -webkit-transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s;
  transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s;
}
.formSubmit:hover::after{
  left: 0;
  right: auto;
  width: 100%;
}
.formSubmit .TNLSign::before,
.formSubmit .TNLSign::after{
  background: #f9851e;
}
.formSubmit:hover .TNLSign{
  width: 22px;
  height: 22px;
  -webkit-transform: translate(2px, -2px);
  transform: translate(2px, -2px);
  opacity: .8;
}
.formSubmit:hover .TNLSign::before,
.formSubmit:hover .TNLSign::after{
  background: rgb(0, 170, 180);
}
.formSubmit:hover .TNLSign::before{
  left: 6px;
}
.formSubmit:hover .TNLSign::after{
  right: 7px;
}


/* -------------------------------------------
  Slick Slider
------------------------------------------- */
.slick-loading .slick-list{background:#fff}
.slick-next,.slick-prev{position:absolute;top:50%;background:rgba(0,0,0,.6);color:transparent;font-size:0;line-height:0;
  width:40px;height:40px;padding:0;display:block; border:none;outline:0;cursor:pointer;z-index:10;border-radius:50%;
  -webkit-transform:translate(0,-50%);transform:translate(0,-50%)}
.slick-next:hover,.slick-prev:hover{color:transparent;outline:0;background:rgba(14, 149, 138, 0.6)}
.slick-next:focus:before,.slick-next:hover:before{opacity:1}
.slick-next.slick-disabled:before,.slick-prev.slick-disabled:before{opacity:0}
.slick-next:before,.slick-prev:before{font-size:30px;line-height:1;opacity:.85;color:#fff;vertical-align: 4px;-webkit-font-smoothing:antialiased}
.slick-prev{left:15px}
[dir=rtl] .slick-prev{right:-15px;left:auto}
.slick-prev:before{content:'←'}
[dir=rtl] .slick-prev:before{content:'→'}
.slick-next{right:15px}
[dir=rtl] .slick-next{right:auto;left:-15px}
.slick-next:before{content:'→'}
[dir=rtl] .slick-next:before{content:'←'}
.slick-next:hover:before,.slick-prev:hover:before{color:#333}
.slick-dotted.slick-slider{margin-bottom:30px}
.slick-dots{display:none}
.slick-slider{position:relative;display:block;box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-khtml-user-select:none;-ms-touch-action:pan-y;touch-action:pan-y;-webkit-tap-highlight-color:transparent}
.slick-list{position:relative;display:block;overflow:hidden;margin:0;padding:0}
.slick-list:focus{outline:0}
.slick-list.dragging{cursor:pointer}s
.slick-slider .slick-list,.slick-slider .slick-track{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}
.slick-track{position:relative;top:0;left:0;display:block;margin-left:auto;margin-right:auto}
.slick-track:after,.slick-track:before{display:table;content:''}
.slick-track:after{clear:both}
.slick-loading .slick-track{visibility:hidden}
.slick-slide{display:none;float:left;height:100%;min-height:1px}
[dir=rtl] .slick-slide{float:right}
.slick-slide img{display:block}
.slick-slide.slick-loading img{display:none}
.slick-slide.dragging img{pointer-events:none}
.slick-initialized .slick-slide{display:block}
.slick-loading .slick-slide{visibility:hidden}
.slick-vertical .slick-slide{display:block;height:auto;border:1px solid transparent}
.slick-arrow.slick-hidden{display:none}


/* -------------------------------------------
  Recruit
------------------------------------------- */
#recruitEC{
  background-size: contain;
  position: relative;
  bottom: -4vw;
  right: -22px;
  width: calc(97% - 480px);
}
#recruitHeadCopy1{
  font-size: 4.5rem;
  line-height: 1.8;
  letter-spacing: .05em;
  margin: 7.5vw 0 0;
}
#recruitHeadCopy2{
  font-size: 4rem;
  line-height: 1.8;
  letter-spacing: .05em;
  margin: 0;
}

.recruitFeatures .sp,
.recruitPhilosophy .sp,
.recruitWLB .sp,
.recruitInterview .sp,
.recruitGDL .sp,
.rctAbout .sp,
.rctForm .sp{
  display: none;
}
.recruitFeatures .pageST .letAnim{
  line-height: 1.5;
}

/* 特徴パララックス */
#stage:has(.recruitHead){
  overflow: inherit;
}
#pageHead.recruitHead{
  overflow: hidden;
  padding-bottom: 4vw;
  margin-bottom: -4vw;
}
.recruitPhilosophy,
.recruitWLB,
.recruitInterview,
.recruitGDL,
.rctAbout,
.rctForm{
  overflow: hidden;
}
.recruitFeatures{
  padding-bottom: 50px;
  position: relative;
}
.recruitFeatures .pageSTWrapp{
  padding-bottom: 0;
  position: sticky;
  top: 0;
  height: 100vh;
  z-index: 2;
  pointer-events: none;
}
.rctStickyWrapp{
  background: #EFEFEF;
  background: linear-gradient(180deg,rgba(239, 239, 239, 0) 0%, rgba(239, 239, 239, 1) 10%, rgba(239, 239, 239, 1) 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
  position: sticky;
  overflow: hidden;
  top: 0;
}
.rctStickyWrapp.first-block{
  margin-top: calc(-100vh + 126px);
}
.rctStickyWrapp .innerWrapp{
  gap: 0 70px;
  padding-block: 0;
  height: 100%;
  width: 100%;
}
.rctStickyWrapp .innerWrapp .rctFtCon{
  padding-top: 120px;
}

.rctFtItem{
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  padding-block: 70px;
}
.rctFtCon{
  box-sizing: border-box;
  max-width: 600px;
  width: 50%;
}
.rctFtTit{
  color: #1d7e52;
  font-size: 2.6rem;
  line-height: 1.8;
  letter-spacing: .03em;
  margin: 0;
}
.rctFtTxt{
  font-size: 1.5rem;
  letter-spacing: .05em;
  line-height: 1.8;
  margin: 35px 0 0;
}
.rctFtImg{
  box-sizing: border-box;
  border-radius: 80px 0 0 80px;
  overflow: hidden;
  max-height: 90vh;
  aspect-ratio: 1 / 1;
  flex: 1;
  margin-right: calc(50% - 50vw);
}
.rctFtImg .BBIM,
.rctFtImg img{
  border-radius: 0;
  height: 100%;
  width: 100%;
  max-width: inherit;
  object-fit: cover;
  display: block;
}

.recruitPhilosophy .innerWrapp{
  padding-block: 100px 64px;
}
.rctPhWrapp{
  justify-content: space-between;
  align-items: flex-end;
  gap: 0 50px;
}
.rctPhWrapp > div{
  flex: 1;
}
.rctPhCon{
  --rctPhConBR: 50px;
  --rctPhConMRL1: 84px;
  --rctPhConMRL2: 50px;
  border: 3px solid;box-sizing: border-box;
  padding-block: 46px 60px;
}
.rctPhCon01{
  --rctPhConColor: #009dd9;
  border-color: var(--rctPhConColor);
  border-left: none;
  border-radius: 0 var(--rctPhConBR) var(--rctPhConBR) 0;
  margin: 64px 0 0 calc(-1 * var(--rctPhConMRL1));
  padding-inline: var(--rctPhConMRL1) var(--rctPhConMRL2);
}
.rctPhCon02{
  --rctPhConColor: #f96602;
  border-color: var(--rctPhConColor);
  border-right: none;
  border-radius: var(--rctPhConBR) 0 0 var(--rctPhConBR);
  margin: 0 calc(-1 * var(--rctPhConMRL1)) 0 0;
  padding-inline: var(--rctPhConMRL2) var(--rctPhConMRL1);
}
.rctPhCon03{
  --rctPhConColor: #1d7e52;
  border-color: var(--rctPhConColor);
  border-left: none;
  border-radius: 0 var(--rctPhConBR) var(--rctPhConBR) 0;
  max-width: 800px;
  margin: 58px 0 0 calc(-1 * var(--rctPhConMRL1));
  padding-inline: var(--rctPhConMRL1) var(--rctPhConMRL2);
}
.rctPhTit{
  border-bottom: 3px solid var(--rctPhConColor);
  color: var(--rctPhConColor);
  line-height: 1.5;
  padding-bottom: .5em;
}
.rctPhCon01 .rctPhTit,
.rctPhCon03 .rctPhTit{
  margin-right: calc(-1 * var(--rctPhConMRL2));
}
.rctPhCon02 .rctPhTit{
  margin-left: calc(-1 * var(--rctPhConMRL2));
  padding-left:  var(--rctPhConMRL2);
}
.rctPhCon01 .rctPhTit,.rctPhCon02,.rctPhCon03{
  position: relative;
}
.rctPhCon01 .rctPhTit .rctPhDeco,
.rctPhCon02 .rctPhDeco,
.rctPhCon03 .rctPhDeco{
  background: #FFF;
  position: absolute;
  stroke-width: 3px;
  margin-inline: -1px;
  width: 68px;
}
.rctPhCon01 .rctPhTit .rctPhDeco{
  stroke: #009dd9;
  bottom: -16px;
  right: 15px;
}
.rctPhCon02 .rctPhDeco{
  stroke: #f96602;
  right: 15px;
  bottom: calc(100% - 13px);
}
.rctPhCon03 .rctPhDeco{
  stroke: #1d7e52;
  left: 15px;
  bottom: -16px;
}
.rctPhCon03 .rctPhTit{
  max-width: 600px;
  margin-left: auto;
}
.rctPhCon03 .rctPhTxt{
  max-width: calc(600px - var(--rctPhConMRL2));
  margin-left: auto;
  padding-left: var(--rctPhConMRL2);
}

.recruitWLB .innerWrapp{
  padding-bottom: 130px;
}
.rctWLBConWrapp{
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  gap: 0 50px;
  box-sizing: border-box;
}
.rctWLBConTxt{
  width: 550px;
}
.rctWLBConImg{
  flex: 1;
  margin-right: calc(50% - 50vw);
}
.rctWLBConImg .BBIM, .rctWLBConImg  img{
  max-width: inherit;
}
.rctMarker{
  font-weight: 700;
  border-bottom: 2px dotted #f96602;
}

.rctWLBLists{
  display: flex;
  justify-content: space-between;
  gap: 33px;
  flex-wrap: wrap;
  margin: 58px 0 0;
  padding: 0;
}
.rctWLBList{
  box-sizing: border-box;
  background: #FFF;
  box-shadow: 0 0 10px rgba(0,0,0,.12);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px;
  min-height: 88px;
}
.rctWLBList p{
  color: #f96602;
  font-size: 1.8rem;
  margin: 0 auto;
  padding-left: 52px;
  position: relative;
  width: fit-content;
}
.rctWLBList p::before{
  content: "";
  background: url(../images/recruit/ico_logo_lightgray.svg) center center / contain no-repeat;
  height: 35px;
  width: 35px;
  position: absolute;
  top: calc(50% - 16px);
  left: 0;
}
.rctWLBList:nth-of-type(1){
  width: 34%;
}
.rctWLBList:nth-of-type(2){
  width: 22.5%;
}
.rctWLBList:nth-of-type(3){
  flex: 1;
}
.rctWLBList:nth-of-type(4){
  width: 27.8%;
}
.rctWLBList:nth-of-type(5){
  width: 26.8%;
}
.rctWLBList:nth-of-type(6){
  flex: 1;
}

.rctWLBBtns{
  margin-top: 74px;
  justify-content: center;
  align-items: flex-end;
  gap: 0 60px;
}
.rctWLBBtns .LBB01{
  border-radius: 100vh;
  font-size: 1.6rem;
  min-width: 210px;
  padding: 25px 48px 25px 30px;
  text-align: center;
}
.rctLink01::before{
  background-color: #f96602;
}
.rctWLBBtns .LBB01 i{
  right: 30px;
}
.rctWLBBtnCopy{
  font-size: 1.6rem;
  padding: 0 .3em 0 .8em;
  margin: 0 auto 10px;
  text-align: center;
  position: relative;
  width: fit-content;
}
.rctWLBBtnCopy::before,
.rctWLBBtnCopy::after{
  position: absolute;
  top: 0.25rem;
  height: 1.5rem;
  content: '';
}
.rctWLBBtnCopy::before{
  border-left: solid 2px;
  left: 0;
  transform: rotate(-22deg);
}
.rctWLBBtnCopy::after{
  border-right: solid 2px;
  right: 0;
  transform: rotate(22deg);
}

.recruitInterview{
  border-radius: 0 220px 220px 0;
}
.recruitInterview .innerWrapp{
  padding-block: 100px 175px;
}
.rctINWrapp01{
  margin-top: 120px;
}
.rctINImgBox{
  box-sizing: border-box;
  padding: 16px 0 22px;
  position: relative;
  width: 40%;
}
.rctINImgBox::before{
  background: var(--rctINColor);
  content: "";
  border-radius: 30px;
  position: absolute;
  top: 0;
  bottom: 0;
}
.rctBlue{
  --rctINColor: #009dd9;
  --rctINDarkColor: #16798e;
}
.rctGreen{
  --rctINColor: #4ab05b;
  --rctINDarkColor: #1d7e52;
  --rctINColor2: #1d7e52;
  --rctINBG: #f1faf1;
}
.rctOrange{
  --rctINColor2: #f96602;
  --rctINBG: #fdefe5;
}
.rctWhtOrange{
  --rctINColor2: #f96602;
  --rctINBG: #FFF;
}
.rctWhtGreen{
  --rctINColor2: #1d7e52;
  --rctINBG: #FFF;
}
.rctWhtBlue{
  --rctINColor2: #009dd9;
  --rctINBG: #FFF;
}
.rctINImgBox p{
  color: #FFF;
  position: relative;
}
.rctINName{
  font-size: 2rem;
  margin-bottom: 17px;
  position: relative;
}
.rctINName .small{
  margin-left: 1em;
}
.rctINImgBox .BBIM,
.rctINImgBox .BBIM img{
  border-radius: 0;
  max-width: 100%;
}
.rctINCareer{
  line-height: 2.5;
  margin: 15px 0 0;
}
.rctINQA{
  line-height: 1.5;
  position: relative;
}
.rctINQ{
  color: var(--rctINDarkColor);
  font-size: 2rem;
  padding-left: 1.8em;
  position: relative;
}
.rctINA + .rctINQ{
  margin-top: 50px;
}
.rctINQ::before{
  color: var(--rctINColor);
  content: "Q.";
  font-family: "Figtree", sans-serif; font-optical-sizing: auto; font-style: normal;
  font-size: 2.9rem;
  font-weight: bold;
  position: absolute;
  left: 0;
  top: -.15em;
}
.rctINWrapp01.first,
.rctINWrapp02.first,
.pageST + .rctINWrapp01,
.pageST + .rctINWrapp02{
  margin-top: 90px;
}
.rctINWrapp01 .rctINImgBox::before{
  right: 20%;
  left: calc(50% - 50vw);
}
.rctINWrapp01.rctReverse{
  flex-direction: row-reverse;
}
.rctINWrapp01.rctReverse .rctINImgBox::before{
  left: 20%;
  right: calc(50% - 50vw);
}
.rctINWrapp01.rctReverse .rctINImgBox p{
  padding-left: calc(20% + 30px);
}
.rctINWrapp01 .rctINQA{
  width: 53%;
}
.rctINWrapp02.first{
  margin-top: 160px;
}
.rctINWrapp02{
  margin-top: 50px;
  padding: 38px 50px 60px 0;
  position: relative;
}
.rctINWrapp02.rctReverse{
  padding-inline: 50px 0;
}
.rctINWrapp02 .rctINWrappInner{
  max-width: 900px;
}
.rctINWrapp02.rctReverse .rctINWrappInner{
  margin-left: auto;
}
.rctINWrapp02::before{
  background: var(--rctINBG);
  content: "";
  border-radius: 30px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: calc(50% - 50vw);
}
.rctINWrapp02.rctReverse::before{
  left: 0;
  right: calc(50% - 50vw);
}
.rctINWrapp02 .rctINQ::before,
.rctINWrapp02 .rctINName,
.rctINWrapp02 .rctINQ{
  color: var(--rctINColor2);
}
.rctINWrapp02 .rctINName{
  margin-bottom: 45px;
}

.recruitGDL .innerWrapp{
  padding-top: 120px;
}

.rctFlow{
  margin: 30px 0 0;
}

.rctFMWrapp{
  margin: 30px 0 0;
  padding: 52px 58px;
}
.rctFMWrapp > p{
  margin: 0;
}
.rctForm .tabBtns{
  gap: 0 6px;
}
.rctForm .tabBtn{
  display: flex;
  max-width: 228px;
  width: 33.33%;
}
.rctForm .tabBtnInner{
  box-sizing: border-box;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-inline: 10px;
  height: 100%;
  width: 100%;
}


/* -------------------------------------------
 Accordion
------------------------------------------- */
.rctGreen{
  --rctAccMain: #4ab05b;
  --rctAccLight: #e0f0ee;
  --rctAccCloseImg: url("../images/recruit/ico_closeG.svg");
}
.rctBlue{
  --rctAccMain: #009dd9;
  --rctAccSmoke: #65a79e;
  --rctAccCloseImg: url("../images/recruit/ico_closeB.svg");
}
.rctAcc{
  background: var(--rctAccMain);
}
.rctAcc + .rctAcc{
  margin-top: 50px;
}
.rctAccTit{
  color: #FFF;
  cursor: pointer;
  font-size: 3rem;
  line-height: 1.5;
  display: flex;
  list-style: none;
  letter-spacing: .1em;
  justify-content: space-between;
  align-items: center;
  padding: 15px 58px;
  text-align: center;
  transition: .2s;
  min-height: 70px;
}
.rctAccTit::-webkit-details-marker {
  display: none;
}
.rctAccTit:hover{
  opacity: .8;
}
.rctAccTit::before,
.rctAccTit::after{
  content: "";
  width: 90px;
}
.rctAccTit::before{
  background: url(../images/recruit/ico_logo_wht.svg) left center / contain no-repeat;
  height: 35px;
}
.rctAccTit::after{
  background: url(../images/recruit/ico_open.svg) right center / contain no-repeat;
  height: 18px;
}
.rctAcc[open] .rctAccTit::after{
  background-image: url(../images/recruit/ico_close.svg);
}
.rctAccTitInner{
  flex: 1;
}
.rctAccCon{
  background: var(--rctAccMain);
  padding: 0 58px 58px 58px;
}
.rctAccCon *{
  box-sizing: border-box;
}
.rctAccInner{
  background: #FFF;
  border-radius: 6px;
  padding: 45px 60px 58px;
}
.rctACTit01{
  text-align: center;
}
.rctACTit02{
  color: #009dd9;
  font-size: 2rem;
  line-height: 1.5;
  margin: 40px 0 0;
}
.rctGDLDetail{
  margin: 46px 0 0;
}
.rctGDLDetail .gdlDT,
.rctGDLDetail .gdlDD{
  font-size: 1.6rem;
  line-height: 1.8;
  padding-block: 20px;
}
.rctGDLDetail .gdlDT{
  background: var(--rctAccLight);
  display: flex;
  align-items: center;
  justify-content: center;
  padding-inline: 15px;
  margin: 0 0 6px;
  text-align: center;
  width: 285px;
}
.rctGDLDetail .gdlDD{
  background: #FFF;
  border-bottom: 2px solid var(--rctAccLight);
  padding-inline: 26px 0;
  margin: 0 0 2px;
  width: calc(100% - 285px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.rctGDLDetail .gdlDD:last-child{
  border: none;
}
.rctGDLDetail .gdlDD .gdlDDInner{
  margin: 0;
  width: 100%;
}
.NList{
  padding-left: .8em;
}
.NList .NListItem{
  position: relative;
}
.NList .NListItem::before{
  content: "・";
  position: absolute;
  top: .05em;
  left: -1em;
}
.rctACNote{
  background: #efefef;
  padding: 12px;
  max-width: 100%;
  margin: 40px 0 0;
  width: fit-content;
}
.rctACTxt{
  margin: 8px 0 0;
}
.rctACTxt.st20{
  line-height: 1.8;
}
.rctAccClose{
  background: var(--rctAccCloseImg) center center / contain no-repeat;
  border: none;
  cursor: pointer;
  display: block;
  outline: none;
  text-indent: 400%;
  white-space: nowrap;
  overflow: hidden;
  padding: 0;
  margin: 40px auto 0;
  height: 18px;
  width: 91px;
  transition: .2s;
}
.rctAccClose:hover{
  opacity: .8;
}


/* -------------------------------------------
 CSS Animation
------------------------------------------- */
/* Common Animation */
.GNLink, .GNLink::after, .ANLink, .ANTelSign, .ANResSign, .AMFIPSign, .FTelNum, .instaLink, .BreadcrumbList a, .BreadcrumbList a::after,
.tLink01, .tLink01::after, .ONItem a::before, .ORTNum, .ORTSign, .ORInstaLogo, .LSign01, .LSign01::before, .LSign01::after,
.LSign02, .LSign03, .TNLSign, .TNLSign::before, .TNLSign::after, .TNLink, .TNKind, .TBCopy, .TBSign, .TBSign::before, .TBSign::after, .TBIco,
.BBNLink, .BBLSign, .BBLSign::before, .BBLSign::after, .OSOSign, .BVResBT::after, .BVTelBT::after, .BVResIco, .BVTelIco,
.fivePILink, .fivePIsign, .MDSLink, .MDSLink::before, .MDSLSign, .GMNIco, .GMNIcoW, .graySign, .graySign::before, .graySign::after, .SPMIco,
.IBNLink, .ALSign, .ALSign::before, .ALSign::after, .ALThumb, .CSNLink, .CSNSign, .keyLink, .colCatLink, .newsBody p a, .newsBody p a::after,
.indPageNavi a, .indPageNavi li > span, .NLLink, .NLTitle, .symNavLink, .SNLSign, .TBDep, .BVBTShadow, .NLSign  {
  -webkit-transition: all .15s ease-in-out .05s; transition: all .15s ease-in-out .05s}

#globalHead, .homeLink, #GNav, .FTElSign, .fixedBTLink::after, .LBBox::after, .LBBlack::after, #retTop:before, #retTop:after, .TBLink::after,
.BBIM::after, .slick-next, .slick-prev, .slick-next:before, .slick-prev:before, .OSOLink::after, .GMNLink::after, .SPMLink::after,
.ALLink::after, .CSNLink::after, .keyLink::after, .link_page:before, .link_page:after, .previousEntry a:after, .previousEntry > span:after, .returnList a:after,
.nextEntry a:after, .nextEntry > span:after, .NLLink::after, .symNavLink::after {
 -webkit-transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s; transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s}

.fixedBTLink { -webkit-transition: all .2s ease-in-out .1s; transition: all .2s ease-in-out .1s}

.ALThumb img, .NLLink img, .NLNoImage, .NLNoImage::after { -webkit-transition: all .25s ease-in-out .05s; transition: all .25s ease-in-out .05s}

.fixedBT, #sideFixBT { -webkit-transition: all .35s ease-in-out .1s; transition: all .35s ease-in-out .1s}

/* Standerd */
@-webkit-keyframes fadeIn { 0%{ opacity: 0} 100%{ opacity: 1} }
@keyframes fadeIn { 0%{ opacity: 0} 100%{ opacity: 1} }
.fadeIn { -webkit-animation: fadeIn .75s ease-in-out; animation: fadeIn .75s ease-in-out; -webkit-animation-fill-mode:both; animation-fill-mode:both}
.fadeIn02 { -webkit-animation: fadeIn 1s ease-in-out; animation: fadeIn 1s ease-in-out; -webkit-animation-fill-mode:both; animation-fill-mode:both}
.fadeIn03 { -webkit-animation: fadeIn 1.2s ease-in-out; animation: fadeIn 1.2s ease-in-out; -webkit-animation-fill-mode:both; animation-fill-mode:both}

@-webkit-keyframes fadeOut { 0%{ opacity: 1} 100%{ opacity: 0} }
@keyframes fadeOut { 0%{ opacity: 1} 100%{ opacity: 0} }
.fadeOut { -webkit-animation: fadeOut .6s ease-in-out; animation: fadeOut .6s ease-in-out;
-webkit-animation-fill-mode:both; animation-fill-mode:both}

@-webkit-keyframes fadeDown {
  0%,25%{ -webkit-transform: translate3d(0,-30px,0); opacity: 0} 100%{ -webkit-transform:none; opacity: 1} }
@keyframes fadeDown { 0%,25%{ transform: translate3d(0,-30px,0); opacity: 0} 100%{ transform:none; opacity: 1} }
#globalHeader, .fadeDown01 {
  -webkit-animation: fadeDown .8s ease-in-out; animation: fadeDown .8s ease-in-out}
.fadeDown02, #homeLogo { -webkit-animation: fadeDown 1s ease-in-out; animation: fadeDown 1s ease-in-out}

@-webkit-keyframes fadeUp {
  0%,25%{ -webkit-transform: translate3d(0,20px,0); opacity: 0} 100%{ -webkit-transform:none; opacity: 1} }
@keyframes fadeUp { 0%,25%{ transform: translate3d(0,20px,0); opacity: 0} 100%{ transform:none; opacity: 1} }
.fadeUp01, #firstVBT { -webkit-animation: fadeUp .65s ease-in-out; animation: fadeUp .65s ease-in-out}
.fadeUp02, #recruitBT { -webkit-animation: fadeUp .8s ease-in-out; animation: fadeUp .8s ease-in-out}
.fadeUp03 { -webkit-animation: fadeUp .95s ease-in-out; animation: fadeUp .95s ease-in-out}
.fadeUp04 { -webkit-animation: fadeUp 1.1s ease-in-out; animation: fadeUp 1.1s ease-in-out}
.fadeUp05 { -webkit-animation: fadeUp 1.25s ease-in-out; animation: fadeUp 1.25s ease-in-out}
.fadeUp06 { -webkit-animation: fadeUp 1.4s ease-in-out; animation: fadeUp 1.4s ease-in-out}

@-webkit-keyframes leftIn {
  0%,25%{ -webkit-transform: translate3d(-30px,0,0); opacity: 0} 100%{ -webkit-transform:none; opacity: 1} }
@keyframes leftIn { 0%,25%{ transform: translate3d(-30px,0,0); opacity: 0} 100%{ transform:none; opacity: 1} }
.leftIn00 { -webkit-animation: leftIn .4s ease-in-out; animation: leftIn .4s ease-in-out}
.leftIn01 { -webkit-animation: leftIn .6s ease-in-out; animation: leftIn .6s ease-in-out}
.leftIn02 { -webkit-animation: leftIn .8s ease-in-out; animation: leftIn .8s ease-in-out}
.leftIn03 { -webkit-animation: leftIn 1s ease-in-out; animation: leftIn 1s ease-in-out}
.leftIn04 { -webkit-animation: leftIn 1.15s ease-in-out; animation: leftIn 1.15s ease-in-out}

@-webkit-keyframes rightIn {
  0%,25%{ -webkit-transform: translate3d(30px,0,0); opacity: 0} 100%{ -webkit-transform:none; opacity: 1} }
@keyframes rightIn { 0%,25%{ transform: translate3d(30px,0,0); opacity: 0} 100%{ transform:none; opacity: 1} }
.rightIn00 { -webkit-animation: rightIn .4s ease-in-out; animation: rightIn .4s ease-in-out}
.rightIn01,#TCharaContainer,#sideFixBT { -webkit-animation: rightIn .6s ease-in-out; animation: rightIn .6s ease-in-out}
.rightIn02, #trigger-overlay { -webkit-animation: rightIn .8s ease-in-out; animation: rightIn .8s ease-in-out}
.rightIn03 { -webkit-animation: rightIn 1s ease-in-out; animation: rightIn 1s ease-in-out}
.rightIn04 { -webkit-animation: rightIn 1.15s ease-in-out; animation: rightIn 1.15s ease-in-out}

@-webkit-keyframes scaleUp {0%,30%{-webkit-transform:scale(0);opacity:0} 100%{-webkit-transform: scale(1);opacity:1}}
@keyframes scaleUp {0%,30%{transform:scale(0);opacity:0} 100%{transform: scale(1);opacity:1}}
.scaleUp01 {
  -webkit-animation: scaleUp .5s cubic-bezier(.075,.82,.165,1); animation: scaleUp .5s cubic-bezier(.075,.82,.165,1);
  -webkit-transform-origin:center; transform-origin:center}
.scaleUp02 {
  -webkit-animation: scaleUp .66s ease-in-out; animation: scaleUp .66s ease-in-out;
  -webkit-transform-origin:center; transform-origin:center}
.scaleUp03 {
  -webkit-animation: scaleUp 1s cubic-bezier(.075,.82,.165,1); animation: scaleUp 1s cubic-bezier(.075,.82,.165,1);
  -webkit-transform-origin:center; transform-origin:center}
.squareBG {
  -webkit-animation: scaleUp .65s cubic-bezier(.075,.82,.165,1); animation: scaleUp .65s cubic-bezier(.075,.82,.165,1);
  -webkit-transform-origin:right center; transform-origin:right center}

/* Lettering Animation */
@-webkit-keyframes typing01 {0%,25%{-webkit-transform:translate3d(-10px,0,0);opacity:0} 100%{-webkit-transform:none;opacity:1}}
@keyframes typing01 {0%,25%{transform:translate3d(-10px,0,0);opacity:0} 100%{transform:none;opacity:1}}
.onChar1{display:inline-block;-webkit-animation:typing01 .2s ease;animation:typing01 .2s ease}.onChar2{display:inline-block;-webkit-animation:typing01 .3s ease;animation:typing01 .3s ease}.onChar3{display:inline-block;-webkit-animation:typing01 .4s ease;animation:typing01 .4s ease}.onChar4{display:inline-block;-webkit-animation:typing01 .5s ease;animation:typing01 .5s ease}.onChar5{display:inline-block;-webkit-animation:typing01 .6s ease;animation:typing01 .6s ease}.onChar6{display:inline-block;-webkit-animation:typing01 .7s ease;animation:typing01 .7s ease}.onChar7{display:inline-block;-webkit-animation:typing01 .8s ease;animation:typing01 .8s ease}.onChar8{display:inline-block;-webkit-animation:typing01 .9s ease;animation:typing01 .9s ease}.onChar9{display:inline-block;-webkit-animation:typing01 1s ease;animation:typing01 1s ease}.onChar10{display:inline-block;-webkit-animation:typing01 1.1s ease;animation:typing01 1.1s ease}.onChar11{display:inline-block;-webkit-animation:typing01 1.2s ease;animation:typing01 1.2s ease}.onChar12{display:inline-block;-webkit-animation:typing01 1.3s ease;animation:typing01 1.3s ease}.onChar13{display:inline-block;-webkit-animation:typing01 1.4s ease;animation:typing01 1.4s ease}.onChar14{display:inline-block;-webkit-animation:typing01 1.5s ease;animation:typing01 1.5s ease}.onChar15{display:inline-block;-webkit-animation:typing01 1.55s ease;animation:typing01 1.55s ease}.onChar16{display:inline-block;-webkit-animation:typing01 1.6s ease;animation:typing01 1.6s ease}.onChar17{display:inline-block;-webkit-animation:typing01 1.65s ease;animation:typing01 1.65s ease}.onChar18{display:inline-block;-webkit-animation:typing01 1.7s ease;animation:typing01 1.7s ease}.onChar19{display:inline-block;-webkit-animation:typing01 1.75s ease;animation:typing01 1.75s ease}.onChar20{display:inline-block;-webkit-animation:typing01 1.8s ease;animation:typing01 1.8s ease}.onChar21{display:inline-block;-webkit-animation:typing01 1.85s ease;animation:typing01 1.85s ease}.onChar22{display:inline-block;-webkit-animation:typing01 1.9s ease;animation:typing01 1.9s ease}.onChar23{display:inline-block;-webkit-animation:typing01 1.95s ease;animation:typing01 1.95s ease}.onChar24{display:inline-block;-webkit-animation:typing01 2s ease;animation:typing01 2s ease}.onChar25{display:inline-block;-webkit-animation:typing01 2.05s ease;animation:typing01 2.05s ease}.onChar26{display:inline-block;-webkit-animation:typing01 2.1s ease;animation:typing01 2.1s ease}.onChar27{display:inline-block;-webkit-animation:typing01 2.15s ease;animation:typing01 2.15s ease}.onChar28{display:inline-block;-webkit-animation:typing01 2.2s ease;animation:typing01 2.2s ease}.onChar29{display:inline-block;-webkit-animation:typing01 2.25s ease;animation:typing01 2.25s ease}.onChar30{display:inline-block;-webkit-animation:typing01 2.3s ease;animation:typing01 2.3s ease}.onChar31{display:inline-block;-webkit-animation:typing01 2.35s ease;animation:typing01 2.35s ease}.onChar32{display:inline-block;-webkit-animation:typing01 2.4s ease;animation:typing01 2.4s ease}.onChar33{display:inline-block;-webkit-animation:typing01 2.45s ease;animation:typing01 2.45s ease}.onChar34{display:inline-block;-webkit-animation:typing01 2.5s ease;animation:typing01 2.5s ease}.onChar35{display:inline-block;-webkit-animation:typing01 2.55s ease;animation:typing01 2.55s ease}.onChar36{display:inline-block;-webkit-animation:typing01 2.6s ease;animation:typing01 2.6s ease}.onChar37{display:inline-block;-webkit-animation:typing01 2.65s ease;animation:typing01 2.65s ease}.onChar38{display:inline-block;-webkit-animation:typing01 2.7s ease;animation:typing01 2.7s ease}.onChar39{display:inline-block;-webkit-animation:typing01 2.75s ease;animation:typing01 2.75s ease}.onChar40{display:inline-block;-webkit-animation:typing01 2.8s ease;animation:typing01 2.8s ease}

.thc02 .onChar1{display:inline-block;-webkit-animation:typing01 1s ease;animation:typing01 1s ease}.thc02 .onChar2{display:inline-block;-webkit-animation:typing01 1.1s ease;animation:typing01 1.1s ease}.thc02 .onChar3{display:inline-block;-webkit-animation:typing01 1.2s ease;animation:typing01 1.2s ease}.thc02 .onChar4{display:inline-block;-webkit-animation:typing01 1.3s ease;animation:typing01 1.3s ease}.thc02 .onChar5{display:inline-block;-webkit-animation:typing01 1.4s ease;animation:typing01 1.4s ease}.thc02 .onChar6{display:inline-block;-webkit-animation:typing01 1.5s ease;animation:typing01 1.5s ease}.thc02 .onChar7{display:inline-block;-webkit-animation:typing01 1.6s ease;animation:typing01 1.6s ease}.thc02 .onChar8{display:inline-block;-webkit-animation:typing01 1.7s ease;animation:typing01 1.7s ease}.thc02 .onChar9{display:inline-block;-webkit-animation:typing01 1.8s ease;animation:typing01 1.8s ease}.thc02 .onChar10{display:inline-block;-webkit-animation:typing01 1.85s ease;animation:typing01 1.85s ease}.thc02 .onChar11{display:inline-block;-webkit-animation:typing01 1.9s ease;animation:typing01 1.9s ease}.thc02 .onChar12{display:inline-block;-webkit-animation:typing01 1.95s ease;animation:typing01 1.95s ease}.thc02 .onChar13{display:inline-block;-webkit-animation:typing01 2s ease;animation:typing01 2s ease}.thc02 .onChar14{display:inline-block;-webkit-animation:typing01 2.05s ease;animation:typing01 2.05s ease}.thc02 .onChar15{display:inline-block;-webkit-animation:typing01 2.1s ease;animation:typing01 2.1s ease}.thc02 .onChar16{display:inline-block;-webkit-animation:typing01 2.15s ease;animation:typing01 2.15s ease}.thc02 .onChar17{display:inline-block;-webkit-animation:typing01 2.15s ease;animation:typing01 2.15s ease}.thc02 .onChar18{display:inline-block;-webkit-animation:typing01 2.2s ease;animation:typing01 2.2s ease}.thc02 .onChar19{display:inline-block;-webkit-animation:typing01 2.25s ease;animation:typing01 2.25s ease}.thc02 .onChar20{display:inline-block;-webkit-animation:typing01 2.3s ease;animation:typing01 2.3s ease}.thc02 .onChar21{display:inline-block;-webkit-animation:typing01 2.35s ease-in-out;animation:typing01 2.35s ease}.thc02 .onChar22{display:inline-block;-webkit-animation:typing01 2.4s ease;animation:typing01 2.4s ease}.thc02 .onChar23{display:inline-block;-webkit-animation:typing01 2.45s ease;animation:typing01 2.45s ease}.thc02 .onChar24{display:inline-block;-webkit-animation:typing01 2.5s ease;animation:typing01 2.5s ease}

@-webkit-keyframes movTyping {0%,90%{-webkit-transform:translate3d(-10px,10px,0);opacity:0} 100%{-webkit-transform:none;opacity:1}}
@keyframes movTyping {0%,90%{transform:translate3d(-10px,10px,0);opacity:0} 100%{transform:none;opacity:1}}
.movType .onChar1{display:inline-block;-webkit-animation:movTyping 1.5s ease;animation:movTyping 1.5s ease}.movType .onChar2{display:inline-block;-webkit-animation:movTyping 1.6s ease;animation:movTyping 1.6s ease}.movType .onChar3{display:inline-block;-webkit-animation:movTyping 1.7s ease;animation:movTyping 1.7s ease}.movType .onChar4{display:inline-block;-webkit-animation:movTyping 1.8s ease;animation:movTyping 1.8s ease}.movType .onChar5{display:inline-block;-webkit-animation:movTyping 1.9s ease;animation:movTyping 1.9s ease}.movType .onChar6{display:inline-block;-webkit-animation:movTyping 2s ease;animation:movTyping 2s ease}.movType .onChar7{display:inline-block;-webkit-animation:movTyping 2.1s ease;animation:movTyping 2.1s ease}.movType .onChar8{display:inline-block;-webkit-animation:movTyping 2.2s ease;animation:movTyping 2.2s ease}.movType .onChar9{display:inline-block;-webkit-animation:movTyping 2.3s ease;animation:movTyping 2.3s ease}.movType .onChar10{display:inline-block;-webkit-animation:movTyping 2.4s ease;animation:movTyping 2.4s ease}.movType .onChar11{display:inline-block;-webkit-animation:movTyping 2.5s ease;animation:movTyping 2.5s ease}.movType .onChar12{display:inline-block;-webkit-animation:movTyping 2.6s ease;animation:movTyping 2.6s ease}.movType .onChar13{display:inline-block;-webkit-animation:movTyping 2.7s ease;animation:movTyping 2.7s ease}.movType .onChar14{display:inline-block;-webkit-animation:movTyping 2.8s ease;animation:movTyping 2.8s ease}.movType .onChar15{display:inline-block;-webkit-animation:movTyping 2.9s ease;animation:movTyping 2.9s ease}.movType .onChar16{display:inline-block;-webkit-animation:movTyping 3s ease;animation:movTyping 3s ease}.movType .onChar17{display:inline-block;-webkit-animation:movTyping 3.1s ease;animation:movTyping 3.1s ease}

.movType02 .onChar1{display:inline-block;-webkit-animation:movTyping 2.3s ease;animation:movTyping 2.3s ease}.movType02 .onChar2{display:inline-block;-webkit-animation:movTyping 2.4s ease;animation:movTyping 2.4s ease}.movType02 .onChar3{display:inline-block;-webkit-animation:movTyping 2.5s ease;animation:movTyping 2.5s ease}.movType02 .onChar4{display:inline-block;-webkit-animation:movTyping 2.6s ease;animation:movTyping 2.6s ease}.movType02 .onChar5{display:inline-block;-webkit-animation:movTyping 2.7s ease;animation:movTyping 2.7s ease}.movType02 .onChar6{display:inline-block;-webkit-animation:movTyping 2.8s ease;animation:movTyping 2.8s ease}.movType02 .onChar7{display:inline-block;-webkit-animation:movTyping 2.9s ease;animation:movTyping 2.9s ease}.movType02 .onChar8{display:inline-block;-webkit-animation:movTyping 2.9s ease;animation:movTyping 2.9s ease}.movType02 .onChar9{display:inline-block;-webkit-animation:movTyping 3s ease;animation:movTyping 3s ease}.movType02 .onChar10{display:inline-block;-webkit-animation:movTyping 3.1s ease;animation:movTyping 3.1s ease}.movType02 .onChar11{display:inline-block;-webkit-animation:movTyping 3.2s ease;animation:movTyping 3.2s ease}.movType02 .onChar12{display:inline-block;-webkit-animation:movTyping 3.3s ease;animation:movTyping 3.3s ease}.movType02 .onChar13{display:inline-block;-webkit-animation:movTyping 3.4s ease;animation:movTyping 3.4s ease}.movType02 .onChar14{display:inline-block;-webkit-animation:movTyping 3.5s ease;animation:movTyping 3.5s ease}.movType02 .onChar15{display:inline-block;-webkit-animation:movTyping 3.6s ease;animation:movTyping 3.6s ease}.movType02 .onChar16{display:inline-block;-webkit-animation:movTyping 3.7s ease;animation:movTyping 3.7s ease}.movType02 .onChar17{display:inline-block;-webkit-animation:movTyping 3.8s ease;animation:movTyping 3.8s ease}

#THEnCopy .thc01 .onChar3, #THEnCopy .thc01 .onChar11, #THEnCopy .thc01 .onChar22, #THEnCopy .thc02 .onChar5,
#THEnCopy .thc02 .onChar14, #THEnCopy .thc02 .onChar19, #THEnCopy .thc02 .onChar28 { margin-left: 8px}




/* -------------------------------------------
  Text Link Hover
------------------------------------------- */
.tLink01, .newsBody p a { color: #1e8eb7; text-decoration: none; display: inline-block; position: relative}
.tLink01:hover, .newsBody p a:hover { color: #f07700}
.FNList a:hover, .TNList a:hover { color: #f06900}

.BreadcrumbList a::after, .tLink01::after, .FNList a::after, .TNList a::after, .newsBody p a::after {
  content: ''; position: absolute; bottom: -3px; left: 0; background-color: #e57e2e; width: 100%; height: 2px;
  -webkit-transform: scaleX(0); transform: scaleX(0); -webkit-transform-origin: left bottom; transform-origin: left bottom}
.BreadcrumbList a::after { bottom: -1px}
.TNList a::after { bottom: -5px}
.newsBody p a::after { bottom: 2px}
.newsBody p .NBPopIM::after { display: none}

.BreadcrumbList a:hover::after, .tLink01:hover::after, .FNList a:hover::after, .TNList a:hover::after, .newsBody p a:hover::after {
  -webkit-ttransform: scaleX(1); transform: scaleX(1)}

/* -------------------------------------------
  Displey Setting
------------------------------------------- */
.homeLink, #retTop, #botLogo, #ORLogo, .IMST, .IMCopy, .PIBanner {
  text-indent: 400%; white-space: nowrap; overflow: hidden}

.homeLink, #retTop a, .IBNLink {
  text-decoration: none; display: block; cursor: pointer; overflow: hidden}

#globalNav .current { cursor: default}
