@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}

/* Mobile Hide Items */
.GHInner, .footNav, .pageNamePlate { display: none}

/* -------------------------------------------
  Fonts
------------------------------------------- */
body  {
  font-family: -apple-system, "Noto Sans JP", "游ゴシック体", 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; font-optical-sizing: auto; font-style: normal}

.NS400, .FNItem, .botAItem, .ONItem, #mfp_phase_confirm td, #copyright { font-weight: 400}

.NS500, .footCatch, .TNNItem, .TWClient, .TWKind, .compLDD, .WIkind, .DIInfo, .NLCopy { font-weight: 500}

.NS600, #globalNav, #topCatch, .TECopy, .TSTJP, .PTJP, .indPTJP, .pageST, .TMessageCopy, .compLDT, .WCItem,
.formProgress, #mfp_phase_confirm h4, #mfp_phase_confirm th,
.newsBody h2, .newsBody h3, .newsBody h4, .newsBody h5 { font-weight: 600}

.NS700 { font-weight: 700}

.figtree, .FI400, .FI500, .FI600, .FI700, .FI800, #retTop a::before, .topST, .ONItem em, .PSTEn, .linkBT01, .TWTime, .WTime, .TNNTime, .PTEn, .NLTime, .indPageNavi a {
  font-family: "Figtree", sans-serif; font-optical-sizing: auto; font-style: normal}

.FI400, #retTop a::before, .HNMenuSign, .NLTime, .newsTime { font-weight: 400}
.FI500, .ONItem em, .PSTEn, .linkBT01, .TWTime, .indPageNavi a { font-weight: 500}
.FI600, .PTEn .LBT01, .TECap01, .TECap02, .TECap03 { font-weight: 600}
.FI700, .PNPName, .indPTEn { font-weight: 700}
.FI800, .JTypeST::after { font-weight: 800}


/* -------------------------------------------
  Common
------------------------------------------- */
* {min-height: 0vw}

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

.mag0 { margin: 0 !important} .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}

#topST02 .onChar9 { font-size: 2.6rem; font-weight: 300; vertical-align: 14px}

.patent01 { font-size: 2.4rem; font-weight: 300}
.patent02 { color: #555; font-size: 2rem; font-weight: 300; margin-right: -2px; vertical-align: 5px;}

.patentCopyright { font-size: 1.8rem; font-weight: 300; vertical-align: 1px; margin-right: 3px}

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


/* Common Image */
.homeLink, .ANlangSign, .FANlangSign, .ANInstaLink, .FNInstaLink, .ORInstaLink, .botHomeLink, .BATMark, #ORLogo, .accTmark {
 background-image: url(../common_im/sp_common.svg); background-repeat: no-repeat; background-size: 186px 110px}

/* Flex Container
------------------------------------------- */
.flexC, #headNav, .ANList, #globalNav, .NLTit, .formProgress, .mfp_buttons {
  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: rgba(255,255,255,.85); z-index: 100;
  width: 100%; height: 59px; margin: 0; -webkit-transition: all .6s; transition: all .6s}

.GHInner {
  background: rgba(255,255,255,.75); width: 100%; height: 100%; margin: 0 auto; position: relative; z-index: 100}

#homeLogo { position: fixed; top: 16px; left: 5vw; width: 116px; margin: 0; z-index: 9999}

.homeLink { background-position: 0 0; width: 116px; height: 28px; display: block; position: relative; opacity: 1}

.fixed #homeLogo { position: fixed; top: 15px; width: 82px}
.fixed .homeLink { background-position: 0 -30px; width: 82px; height: 20px}

@media (max-width: 767px) {
  #globalHeader { height: 49px} #homeLogo { top: 11px} }

/* Overlay Navi */
#trigger-overlay {
  position: fixed; top: 0; right: 0; text-decoration: none; width: 60px; height: 60px; display: block; z-index: 9999}

.HMBox { position: fixed; top: 21px; right: 5px; width: 36px; height: 34px}

#trigger-overlay::before, #trigger-overlay::after {
  content: ''; position: absolute; top: 0; right: 0; width: 60px; height: 60px; display: block}
#trigger-overlay::before { background: rgba(20,104,173,.9); z-index: -2}
#trigger-overlay::after { background: rgba(0,150,160,.9); -webkit-transform: scale(0); transform: scale(0); z-index: -1}

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


.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)}

.menu-trigger .HMBar {
 background: #f0f0f0; width: 22px; height: 2px; 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: 12px; top: 6px; -webkit-transition-delay: .08s; transition-delay: .08s}
.menu-trigger .HMBar:nth-child(3) { width: 18px; top: 12px; -webkit-transition-delay: 0; transition-delay: 0}

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

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

.menu-trigger.active .HMBar:nth-child(2) {
 -webkit-transform: translate(-30px, 0); transform: translate(-30px, 0); opacity: 0}

.menu-trigger.active .HMBar:nth-child(3) {
 top: 12px; left: -4px; width: 22px; -webkit-transform: rotate(-315deg); transform: rotate(-315deg)}

.fixed #trigger-overlay::before, .fixed #trigger-overlay::after { width: 44px; height: 44px}
.fixed .HMBox { top: 14px; right: -3px}

@media (max-width: 767px) {
  #trigger-overlay, #trigger-overlay::before, #trigger-overlay::after { width: 50px; height: 50px} .HMBox { top: 16px; right: 0} }

/* Overlay */
.overlay {
  position: fixed; top: 0; right: 0; background: rgba(40,40,40,.9);
  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 {
  position: absolute; top: 50%; left: 50%; width: 260px; margin: 0 auto;
  -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%)}

.ORNav { padding: 60px 0; position: relative}

@media (max-height: 640px) { #ORContainer { position: relative; top: inherit; left: inherit; transform: none} }

.overlayNav { margin: 0; padding: 0}

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

.ONItem em { color: #b5b5b5; font-size: 1.4rem; font-style: normal; padding-top: 2px; float: right}

.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: 8px 10px 10px;
  position: relative; display: block; cursor: pointer; overflow: hidden}

.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: 2px; display: block}

.ORActionNav { width: 230px; margin: 30px auto 0}

.ORAppDownload { width: 300px; margin: 40px auto 0}

#ORLogo {
  background: url(../common_im/jp_logo.svg) no-repeat 0 0 / cover; width: 184px; height: 29px; margin: 40px auto 0; opacity: .8}

.ORInsta { width: 100%; height: 30px; margin: 40px 0 0; position: relative}

.ORInstaLink, .FNInstaLink { background-position: -120px 0; width: 30px; height: 30px; margin: 0 auto; opacity: .85; display: block}

/* -------------------------------------------
 Footer
------------------------------------------- */
footer { background: #222; padding: 60px 5vw 60px; position: relative; z-index: 1}

#footInner { margin: 0 auto}

/* Bottom ID */
.footLeft, .footRight { width: 100%}

.footCatch { color: #ddd; font-size: 1.4rem; text-align: center; letter-spacing: .04em; margin: 0}

#botLogo { width: 186px; margin: 45px auto 0}

.botHomeLink { background-position: 0 -50px; width: 186px; height: 60px; display: block; cursor: pointer}

#bottomAdd { margin: 30px auto 0; padding: 0; display: table}

.botAItem { color: #ddd; font-size: 1.5rem; letter-spacing: .05em; margin: 0}
.BAITel { margin-top: 1em}

.BAITLink { color: #ddd; text-decoration: none; padding-left: 15px; display: inline-block; position: relative}

.BATMark { position: absolute; top: 2.5px; left: 1px; background-position: -160px -30px; width: 10px; height: 12px; display: block}
  
.botFax { padding-left: 16px}

.FNInsta { margin: 40px 0 0}

#copyright { color: #c2c2c2; font-size: 1.4rem; text-align: center; letter-spacing: .08em; width: 100%; margin: 40px 0 0; display: block}

@media (max-width: 429px) { .footCatch { font-size: 1.3rem; letter-spacing: .02em}}
@media (max-width: 389px) { .footCatch { font-size: 1.2rem} .botAItem { font-size: 1.4rem; letter-spacing: .03em;} }

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

#retTop { background: rgba(105,105,105,.85); margin: 0; position: relative}

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

#retTop a::before {
 content: 'page top'; position: absolute; bottom: 16px; left: 0; display: block; cursor: pointer; z-index: 1000;
 color: #fff; font-size: 11px; text-align: center; text-indent: .04em; letter-spacing: .04em; width: 100%}

#retTop a::after {
 content: ''; position: absolute; top: 13px; left: 50%; cursor: pointer;
 width: 6px; height: 6px; border-top: 1px solid #fff; border-right: 1px solid #fff; margin-left: -4px;
 -webkit-transform: rotate(-45deg); transform: rotate(-45deg)}

/* -------------------------------------------
 Banner Area
------------------------------------------- */
#mainBanner, #botomBanner { margin-top: 6px; padding-top: 6px; border-top: 1px solid #bbb}
#pageMainBanner { margin-top: 6px}

.MBItem { width: calc(50% - 3px); margin: 0; position: relative}
.BBItem { width: calc(33.33% - 4px); margin: 0; position: relative}

.MBLink, .BBLink { text-decoration: none; padding: 60px 0; display: block; cursor: pointer; overflow: hidden}
.BBLink { padding: 82px 0}

.MBLink::before, .MBLink::after, .BBLink::before, .BBLink::after { content: ''; position: absolute; top: 0; height: 100%}
.MBLink::before, .BBLink::before { left: 0; width: 100%; z-index: -2}
.MBLink::after, .BBLink::after { left: auto; right: 0; background: #0099a2; width: 0; z-index: -1}

.MBTRAVELERS::before { background: #eee}
.MBAccomodation::before { background: #444}

.BBQA::before { background: #555}
.BBCompany::before { background: #909090}
.BBContact::before { background: #f7f7f7; border: 1px solid #ccc; border-right: none}

.MBCopy, .BBCopy { text-align: center; margin: 0}

.MBSubCatch, .MBMainCatch, .MBENCopy, .BBEN, .BBJP { display: block}

.MBSubCatch { font-size: 1.8rem; letter-spacing: .035em;}
.MBTRAVELERS .MBSubCatch, .MBTRAVELERS .MBMainCatch { color: #333}
.MBAccomodation .MBSubCatch, .MBAccomodation .MBMainCatch { color: #e9e9e9}

.MBMainCatch { font-size: 3.6rem; letter-spacing: .05em; margin-top: 22px}

.MBENCopy { font-size: 2.4rem; font-style: normal; letter-spacing: .1em; margin-top: 20px}
.MBTRAVELERS .MBENCopy { color: #f96600}
.MBAccomodation .MBENCopy { color: #aed7f5}


.BBEN { font-size: 3.4rem; letter-spacing: .05em; } .BBJP { font-size: 1.9rem; margin-top: 23px}

.BBQA .BBEN, .BBQA .BBJP { color: #e9e9e9} 
.BBCompany .BBEN, .BBCompany .BBJP { color: #fff} 
.BBContact .BBEN, .BBContact .BBJP { color: #444} 

.MBCurrent { opacity: .6; cursor: default}
.MBTRAVELERS.MBCurrent::before { background: #888}
.MBCurrent::after { display: none}

/* -------------------------------------------
 Main Container
------------------------------------------- */
/* Container
------------------------------------------- */
#topStage, #stage { background: transparent; position: relative; overflow: hidden}
#stage { padding-top: 60px}
#stage::before { content: ''; position: absolute; top: 59px; left: 0; background: #bbb; width: 100vw; height: 1px}

@media (max-width: 767px) { #stage { padding-top: 50px} #stage::before { top: 49px} }

.TSInner { margin: 0 auto; padding: clamp(40px,7.5vw,50px) 5vw 9vw; position: relative}
.topSec { border-top: 1px solid #bbb}

.PTWrapp, .PTWrapp02 { padding: 0 5vw}

.pageWrapp { width: 100%; margin: 0; border-top: 1px solid #bbb}

.pageNamePlate { width: 69px; padding-top: 35px; border-right: 1px solid #bbb}

.PNPName { color: #555; font-size: 2rem; writing-mode: vertical-rl; text-align: center; letter-spacing: .1em; margin: 0 auto;}

.pageContents { width: 100%; overflow: hidden}

.pageWrapp01 { padding: 50px 5vw 44px}
.pageWrapp02 { padding: 50px 5vw 44px; border-top: 1px solid #bbb}

@media (max-width: 480px) { .pageWrapp01, .pageWrapp02 { padding: 40px 5vw 45px} }

.pageSec { margin: 0 auto; position: relative}

.BGGray { background: #e9e9e9}

.MG0 { margin-top: 0 !important} .MG01 { margin-top: 1em !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}


/* Breadcrum Navi
------------------------------------------- */
.breadcrumb { width: 100%; border-top: 1px solid #bbb}

.BreadcrumbNav { margin: 0 auto; padding: 0; position: relative}

.BreadcrumbList { text-align: right; width: calc(100% - 10vw); margin: 0; padding: 9px 5vw; display: inline-block}

.BCLink, .BCCurrent { font-size: 1.3rem; line-height: 1.6; letter-spacing: .05em; display: inline-block}

.BCLink { position: relative}

.BLSign { content: ">"; color: #666; font-size: 1.5rem; text-align: center; width: 1.5em; vertical-align: -1px; display: inline-block}

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

/* Page Eyecatch
------------------------------------------- */
.pageEC { background-repeat: no-repeat; width: calc(50% - 35px); height: 500px; position: relative; z-index: 1}

#travelresEC { background: url(../travelers/images/eyecatch02.webp) no-repeat center / cover}
#accomodationEC { background: url(../partnership/images/eyecatch02.webp) no-repeat center / cover}

.no-webp #travelresEC { background: url(../travelers/images/eyecatch02.jpg) no-repeat center / cover}
.no-webp #accomodationEC { background: url(../partnership/images/eyecatch02.jpg) no-repeat center / cover}

/* Page Titles
------------------------------------------- */
.pageTitle { margin: 110px 0 0}

.officialPTitle { margin: clamp(80px,16vw,100px) 0}

.individualTitle { margin: 86px 0 94px;}

.PTEn, .indPTEn { font-size: clamp(4rem,9vw,5.4rem); letter-spacing: .04em; font-style: normal}
.indPTEn { font-size: 4.2rem}

#travelersPTE, .officialPT { color: #333}
#accPTE { color: #2e4e7e; letter-spacing: .02em}

.PTJP, .indPTJP { color: #1e7ecc; font-size: clamp(1.8rem,4.5vw,2.2rem); letter-spacing: .09em; margin-top: 1.5vw; display: block}
.indPTJP { font-size: 1.9rem; letter-spacing: .1em}

/* Sub Titles
------------------------------------------- */
.topST, .pageST { color: #333; margin: 0; padding: 5px 15px 1px 15px; display: inline-block; position: relative}
.topST { font-size: clamp(3.8rem,6.4vw,5rem); letter-spacing: .04em; margin: 0 0 24px}
.pageST { font-size: clamp(3rem,5vw,3.6rem); letter-spacing: .035em; width: fit-content; margin: 0 0 18px; padding: 10px 15px 13px 13px; overflow: visible}

.topST::before, .topST::after, .pageST::before, .pageST::after, #worksCatTit::before, #worksCatTit::after {
  content: ''; position: absolute; width: .8rem; height: .8rem}
.topST::before, .pageST::before, #worksCatTit::before {
  top: 0; left: 0; border-top: #f1352b solid .3rem; border-left: #f1352b solid .3rem; border-radius: .2rem 0 0 0}
.topST::after, .pageST::after, #worksCatTit::after {
  bottom: 0; right: 0; border-bottom: #f1352b solid .3rem; border-right: #f1352b solid .3rem; border-radius: 0 0 .2rem 0}

.TSTJP { position: absolute; bottom: -54%; left: 15px; color: #1e7ecc; font-size: clamp(1.7rem,2.4vw,1.9rem); display: block}

.PSTEn {
  position: absolute; bottom: -18px; left: 18px; color: #999;
  font-size: clamp(1.4rem,2.3vw,1.6rem); font-style: normal; letter-spacing: .08em; white-space: nowrap; margin: 14px 0 0; 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}

.NTLST { margin-top: 45px}

.stCenter, .PCopyCenter { text-align: center}

@media (max-width: 767px) { .TSTJP { bottom: -52%} .PSTEn { bottom: -16px} }

@media (max-width: 600px) { .TSTJP { bottom: -56%}}

/* Page Copy
------------------------------------------- */
.PCopy16, .PCopy17, .PCopy18, .PCopy19 { letter-spacing: .06em}
.PCopy16 { font-size: 1.6rem}
.PCopy17 { font-size: 1.7rem}
.PCopy18 { font-size: 1.8rem}
.PCopy19 { font-size: 1.9rem}
.PCopy20 { font-size: 2rem}
.PCopy22 { line-height: 2; letter-spacing: .05em}
.PCopy22 { font-size: 2.2rem}

.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: 40px !important}
.PTTPad50 { margin: 0; padding-top: 50px !important}
.PTTPad60 { margin: 0; padding-top: 60px !important}

/* Nav Sign
------------------------------------------- */
.sign01, .sign02 {
  width: 20px; height: 20px; margin-left: 6px; vertical-align: -4px; border-radius: 50%; display: inline-block; position: relative}
.sign01 { background: #459ee5}

.sign01::before, .sign01::after, .sign02::before, .sign02::after { content: ''; position: absolute; top: 50%; height: 2px}
.sign01::before, .sign02::before { left: 5px; width: 10px}
.sign01::before, .sign01::after { background: #fff}
.sign02::before, .sign02::after { background: #37b2e7}
.sign01::after { right: 6px; width: 4px; margin-top: -2px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}

/* Link Button
------------------------------------------- */
.linkBT01 { font-size: 1.8rem; letter-spacing: .1em; text-indent: .1em; text-align: center}

.TWorksBT { margin: 40px 0 0}
.TRecBT { margin: 20px 0 0}
.TNewsBT { position: absolute; top: clamp(50px, 8.5vw, 60px); right: calc(5vw + 30px); margin: 0}

.LBT01 { color: #fff; background: #666; text-decoration: none; width: 31.5%; padding: 15px 0; display: block; position: relative; z-index: 1}
.TWorkLBT { width: 30.75%; margin: 0 auto}
.TRecLBT { width: 30.75%; margin: 0}

@media (max-width: 740px) { .TRecLBT { margin: 25px auto 0} }
@media (max-width: 599px) { .LBT01, .TRecLBT { width: 100%; max-width: 300px} }

/* -------------------------------------------
 Loader
------------------------------------------- */
#tp-loader { position: fixed; top: 0; left: 0; background: #e2e2e2; width: 100vw; height: 100vh; 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}

 /* -------------------------------------------
 Slider Revolution
------------------------------------------- */
.tp-static-layers{position:absolute;z-index:505;top:0;left:0}.tp-caption.tp-hidden-caption,.tp-hide-revslider{visibility:hidden!important;display:none!important}.tp-caption{z-index:1;white-space:nowrap}.tp-caption-demo .tp-caption{position:relative!important;display:inline-block;margin-bottom:10px;margin-right:20px!important}.tp-simpleresponsive .caption,.tp-simpleresponsive .tp-caption{position:absolute;visibility:hidden;-webkit-font-smoothing:antialiased!important}.tp-simpleresponsive img{max-width:none}.tpclear{clear:both}.tp-bullets{z-index:1000;position:absolute;opacity:1;-webkit-transition:opacity .2s ease-out;transition:opacity .2s ease-out;-webkit-transform:translateZ(5px);transform:translateZ(5px)}.tp-bullets.hidebullets{opacity:0}.tp-bullets.simplebullets.round{height:21px}.tp-bullets.simplebullets.round .bullet{cursor:pointer;position:relative!important;background:rgba(0,0,0,.5)!important;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;width:5px!important;height:5px!important;border:8px solid transparent!important;display:inline-block;margin-right:5px!important;margin-bottom:0!important;-webkit-transition:background-color .2s,border-color .2s;transition:background-color .2s,border-color .2s;float:none!important;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box}.tp-bullets.simplebullets.round .bullet.last{margin-right:0}.tp-bullets.simplebullets.round .bullet.selected,.tp-bullets.simplebullets.round .bullet:hover{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;background:#666!important;width:5px!important;height:5px!important;border:8px solid rgba(255,255,255,1)!important}.tparrows{opacity:1;-webkit-transition:opacity .2s ease-out;transition:opacity .2s ease-out;-webkit-transform:translateZ(5000px);transform:translateZ(5000px);-webkit-transform-style:flat;transform-style:flat;-webkit-backface-visibility:hidden;backface-visibility:hidden;z-index:600;position:relative}.tp-leftarrow.default,.tp-rightarrow.default{z-index:100;cursor:pointer;position:relative;width:40px;height:40px}.tparrows.hidearrows{opacity:0}.tp-leftarrow.default{background:url(assets/large_left.png)}.tp-rightarrow.default{background:url(assets/large_right.png)}.tp-leftarrow:hover,.tp-rightarrow:hover{background-position:bottom left}.tp-bannertimer{width:100%;height:5px;background:url(assets/timer.png);position:absolute;z-index:200;top:0}.tp-bannertimer.tp-bottom{bottom:0;height:5px;top:auto}@media only screen and (min-width:0px) and (max-width:479px){.responsive .tp-bullets,.responsive .tparrows{display:none}}.tp-loader{top:50%;left:50%;margin-top: 51px !important;z-index:100;position:absolute}.tp-loader.spinner3{margin:-9px 0 0 -35px;width:70px;text-align:center}.tp-loader.spinner3 .bounce1,.tp-loader.spinner3 .bounce2,.tp-loader.spinner3 .bounce3{width:18px;height:18px;background-color:#fff;box-shadow:0 0 20px 0 rgba(0,0,0,.15);-webkit-box-shadow:0 0 20px 0 rgba(0,0,0,.15);border-radius:100%;display:inline-block;-webkit-animation:tp-bouncedelay 1.4s infinite ease-in-out;animation:tp-bouncedelay 1.4s infinite ease-in-out;-webkit-animation-fill-mode:both;animation-fill-mode:both}.tp-loader.spinner3 .bounce1{-webkit-animation-delay:-.32s;animation-delay:-.32s}.tp-loader.spinner3 .bounce2{-webkit-animation-delay:-.16s;animation-delay:-.16s}@-webkit-keyframes tp-bouncedelay{0%,100%,80%{-webkit-transform:scale(0)}40%{-webkit-transform:scale(1)}}@keyframes tp-bouncedelay{0%,100%,80%{transform:scale(0);-webkit-transform:scale(0)}40%{transform:scale(1);-webkit-transform:scale(1)}}

/* BANNER CONTAINERS */
.tp-bannertimer { display: none}

.tp-banner-container, .tp-banner { width: 100%; height: 600px; position: relative; overflow: hidden}
.tp-banner-container { position: relative}

.tp-banner-container, .tp-banner-fullscreen-container { padding:0}

.tp-banner ul { margin: 0; padding: 0}

.tp-leftarrow.default, .tp-rightarrow.default { margin-top: 0 !important}

.tp-bullets { bottom: 30px !important}

.topMovie { position: absolute; top: 0; width: auto; height: 600px}

#TM01 { right: 0}  #TM02, #TM03 { left: 0}

/* -------------------------------------------
 Top Page
------------------------------------------- */
/* Top Eyecatch */
#topEyecatch { width: 100%; height: 600px; position: relative; overflow: hidden}

.TECopy, #topHeadCopy, .TECap01, .TECap02, .TECap03, #topCatch, #sp-topCatch { position: absolute; left: 6vw; margin: 0}

.TEC01, .TEC02, .TEC03, #topCatch {
  top: 60%; color: #f7f7f7; font-size: clamp(2.8rem,6vw,3.4rem) !important;
  text-shadow: 0 0 5px rgba(0,0,0,.6); letter-spacing: .04em !important}

.TEC02 { margin-top: 6% !important}
.TEC03 { margin-top: 12% !important}
#TEC022 { letter-spacing: 0 !important}

@media (max-width: 720px) { .TEC02 { margin-top: 7% !important} .TEC03 { margin-top: 14% !important} }
@media (max-width: 620px) { .TEC02 { margin-top: 8% !important} .TEC03 { margin-top: 16% !important} }

.TECap01, .TECap02, .TECap03 { top: 60%; font-size: clamp(1.5rem,2vw,1.7rem) !important; letter-spacing: .06em !important;}
.TECap01 { color: #f7f7f7; margin-top: calc(11% + 1vw) !important}
.TECap02 { color: #000; margin-top: calc(17% + 1vw) !important}

@media (max-width: 720px) {
  .TECap01 { color: #f7f7f7; margin-top: calc(12% + 2vw) !important} .TECap02 { color: #000; margin-top: calc(19% + 2vw) !important} }
@media (max-width: 620px) {
  .TECap01 { color: #f7f7f7; margin-top: calc(14.25% + 2vw) !important} .TECap02 { color: #000; margin-top: calc(22.5% + 2vw) !important} }

@media (max-width: 420px) {
  #TP02 .TEC01, #TP02 .TEC02 { font-size: 2.6rem !important} #TP02 .TEC02 { letter-spacing: -.01em !important}
  .TEC02 { margin-top: 36px !important} .TEC03 { margin-top: 72px !important}
  .TECap01, .TECap02 { top: 62%} .TECap01 { margin-top: 15.75% !important} .TECap02 { margin-top: 24.75% !important}
  #TP02 .TECap01 { margin-top: 14.75% !important} }

@media (max-width: 389px) {
  #TP02 .TEC01, #TP02 .TEC02 { font-size: 2.5rem !important} .TEC02 { margin-top: 38px !important} .TEC03 { margin-top: 76px !important}
  .TECap01, .TECap02 { top: 63%} .TECap02 { margin-top: 26.75% !important} }

.TECBlack { color: #000; text-shadow: -1px -1px 3px rgba(255,255,255,.7)}

#sp-topCatch { top: 55vh; color: #e2e2e2; font-size: 7.5vw; letter-spacing: .2em}
.thc02, .thc03 { margin-top: 1.8vw; display: block}
.thc03 { font-size: 1.8vw}
.thc03 .onChar5 { width: 7px; letter-spacing: 0}

.TVOverlay {
  position: absolute; top: 0; left: 0; background-image: linear-gradient(45deg, rgba(0,0,0,0) 50%, rgba(0,0,0,0) 50%);
  background-size: 3px 3px; width: 100%; height: 800px; z-index: 2}

/* Top About and Top Works */
#topAboutST .onChar10 { width: 1.4vw}

.topAboutLogo {
  position: absolute; top: 11.5%; right: 5vw; background: url(../common_im/jp_logo.svg) no-repeat 0 0;
  width: 36%; height: 6.5vw; margin: 0}

.topAboutCopy { font-size: 1.7rem !important; margin: 0; padding-top: clamp(45px,5vw,60px)}

.TAboutList, .TWorksList { margin: clamp(45px,5vw,60px) auto 0; padding: 0}

.TAboutList { padding-bottom: 10px}

.TALItem, .TWLItem { width: 31.5%}

.TALLink { color: #333; text-decoration: none}

.TALImage, .TWLImage { width: 100%; height: auto; display: block; position: relative; overflow: hidden; z-index: 1}

.TALCap { position: absolute; bottom: 10px; left: 10px; color: #fff; font-size: 2.6rem; letter-spacing: .04em; z-index: 5}

.TALName { font-size: 1.6rem; letter-spacing: .06em; margin: 10px 0 0; display: block}

.TWLLink { text-decoration: none}

.TWLName, .WLName { font-size: 1.6rem; letter-spacing: .05em; margin: 20px 0 0}
.WLName { font-size: 1.7rem}

.TWClient { color: #333; line-height: 1.4; margin-bottom: 7px; display: block}

.TWTime, .WTime { color: #777; font-size: 1.4rem}

.TWHyphen { color: #777; font-size: 1.2rem; margin: 0 6px 0 5px; vertical-align: 1px; display: inline-block}
.TWKind, .WKind { color: #777; font-size: 1.5rem}
.WKind { font-size: 1.5rem}

@media (max-width: 767px) { #worksList .TWLItem { width: 48%}}
@media (max-width: 740px) { .topAboutCopy { font-size: 1.6rem !important; line-height: 1.75} }
@media (max-width: 699px) { .TALCap { font-size: 2.2rem} }

@media (max-width: 599px) {
  .topAboutLogo { display: none} .spTAboutLogo { width: 60%; margin: 10px auto 0} .SPTALogo { width: 100%; height: auto}
  .TALCap { font-size: 1.9rem}  }

@media (max-width: 499px) {
  .TALItem, .TWLItem, #worksList .TWLItem { width: 100%; max-width: 400px; margin: 35px auto 0}
  .TALItem:first-of-type, .TWLItem:first-of-type, #worksList .TWLItem:first-of-type { margin-top: 0}}

  @media (max-width: 440px) { .WLName { font-size: 1.6rem}}

/* Top recruit */
.topRecruit { margin-top: 10px; position: relative; overflow: hidden;}

.TRecImage { position: absolute; top: 0; right: 0; width: 74%; height: 35vw; z-index: -1}
.TRecImage img {
  position: absolute; top: 50%; left: 50%; width: 100%; height: auto;
  -webkit-transform: translate(-50%,-50%); transform: translate(-50%,-50%);}

.TRecInfo { background: #fff; width: 54%; margin: 10vw 0 0; z-index: 1;}

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

@media (max-width: 740px) {
  .topRecruit { display: flex; justify-content: flex-start; flex-direction: column; margin-top: 40px}
  .TRecImage { order: 1; position: relative; top: inherit; right: inherit; width: 100%; max-width: 560px; height: auto; margin: 0 auto}
  .TRecImage img { position: relative; top: inherit; left: inherit; -webkit-transform: none; transform: none}
  .TRecInfo { order: 2; width: 100%; margin-top: 30px} .TRecCopy { padding: 0} }

/* Top News */
#topNews { display: block}

.TNewsBT .TRecLBT.LBT01 { width: 100%; margin: 0; padding: 15px}

.TNewsNav { margin-top: 6vw}

.TNNList { margin: 0; padding: 0; border-bottom: 1px solid #bbb}

.TNNItem { font-size: 1.5rem; letter-spacing: .05em; margin: 0; border-top: 1px solid #bbb}
.TNNItem::after { clear: both}

.TNNTime { float: right; color: #666}

.TNNLink { color: #333; text-decoration: none; padding: 26px 0; display: block; position: relative; cursor: pointer; overflow: hidden}

.TNIndexBT { position: absolute; top: 0; right: 0; font-size: 1.6rem; letter-spacing: .05em; text-indent: .02em}

.TNILink {
  color: #555; text-decoration: none; padding: 12px 16px 13px 15px; border: 1px solid #a7a7a7;
  display: block; cursor: pointer; overflow: hidden}

  @media (max-width: 699px) {.TNNItem { line-height: 1.6} .TNNLink { padding: 20px 0;} .TNNTime { float: none; margin-top: 3px; display: block} }

/* -------------------------------------------
 Service
------------------------------------------- */
#appPort { padding-bottom: 10px}

.appPortInfo { font-size: clamp(1.8rem,3vw,2.8rem); margin: 0}

.applicablePortion { width: 100%; height: auto; margin: 40px auto 0; display: block}
.applicablePortion, .appPortIM { border-radius: 40px}

#SGall03 { padding-bottom: 15px}

.servicePS { align-items: center}

.serviceInfo { display: flex; flex-direction: column; width: 58%}

.serviceStIco {
  position: absolute; top: 8px; left: 108%;
  background: url(../service/images/seevice_ico.svg) no-repeat 0 0 / 45px 145px; width: 45px; height: 45px; display: block}
#SSIco02 { background-position: 0 -50px}
#SSIco03 { background-position: 0 -100px}

#ACPTEN { bottom: -25px}

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

.serviceIM01 { width: 36%; height: auto}

.serviceGallery { margin: 3.25% auto 0}

.serviceIM02 { width: 31%}
.SIM01, .SIM02, .appPortIM { width: 100%; height: auto}

@media (max-width: 767px) {
  .appPortInfo { text-align: center} .servicePS, .serviceInfo { display: block !important} .serviceStIco { left: 107%}
  #ACPTEN { bottom: -23px} .serviceInfo { width: 100%} .serviceCopy { padding-top: 41.5vw}
  .serviceIM01 { position: absolute; top: 11vw; left: 0; text-align: center; width: 100%; margin: 30px 0 0; display: block}
  .SIM01 { width: 60%; height: auto} .serviceGallery { margin-top: 4.5%} }

@media (max-width: 600px) {
  .serviceCopy { padding-top: 56%} .serviceIM01 { top: 14%} .SIM01 { width: 70%} .serviceGallery { margin-top: 5.5%} }

@media (max-width: 480px) {
  #appPort { padding: 0} #SGall03 { padding-bottom: 10px} .serviceIM01 { display: none} .serviceCopy { padding-top: 0}
  .serviceIM02 { width: 48%} .serviceIM02:nth-child(n+3) { margin-top: 3.5%} }

@media (max-width: 419px) { .serviceIM02 { width: 100%; margin-top: 3.5%} }

@media (max-width: 389px) { .appPortInfo { font-size: 1.7rem} }
@media (max-width: 369px) { .appPortInfo { font-size: 1.6rem} }

/* -------------------------------------------
 COMPANY
------------------------------------------- */
.TMessageCopy { color: #555; font-size: 1.6rem; line-height: 2.2; letter-spacing: .06em; max-width: 52.75em; margin: 2em auto 0}
.TMessageCopy:first-of-type { margin-top: 60px}
.TMCSignature { text-align: right}

#compOverview { align-items: start; padding-bottom: 20px}

.compST { width: 200px}

.compListBox { width: calc(100% - 240px)}

.compList { margin: 0; padding: 0}

.compList { color: #595959; font-size: 1.5rem; line-height: 1.8; letter-spacing: .075em}

.compLDT { width: 110px; margin: 0; padding: 22px 5px 21px; border-top: 2px solid #3e77cc}
.compLDT:last-of-type { border-bottom: 2px solid #3e77cc}

.compLDD { word-break: break-all; width: calc(100% - 130px); margin: 0; padding: 21px 5px 20px; border-top: 1px solid #bbb}
.compLDD:last-of-type { border-bottom: 1px solid #bbb}
.compLDD .spBlock01, .compLDD .spBlock02 { padding-left: 1em; display: block}
.compLDD .spBlock01 { margin-bottom: -1em}

@media (max-width: 839px) { .CLDFax { display: block} }

@media (max-width: 819px) {
  .compListBox { width: 100%; margin: 45px auto 0} .compLDT { padding-left: 10px}
  .compLDD { width: calc(100% - 140px); padding-left: 10px}
  .compLDD .spBlock01, .compLDD .spBlock02, .CLDFax { padding-left: 0; display: inline} .compLDD .spBlock01 { margin-bottom: 0} }

@media (max-width: 767px) { .TMessageCopy:first-of-type { margin-top: 50px} }

@media (max-width: 679px) {
  .compLDD .spBlock01, .compLDD .spBlock02 { padding-left: 1em; display: block} .compLDD .spBlock01 { margin-bottom: -1em}}

@media (max-width: 620px) { .TMessageCopy br { display: none}}

@media (max-width: 579px) { 
   .TMessageCopy:first-of-type { margin-top: 40px}
  .CLDFax { display: block} .compLDD .spBlock01, .compLDD .spBlock02 { padding-left: 0} }

@media (max-width: 559px) {
  .compList { font-size: 1.5rem} .compLDT { width: 100%; padding: 12px 10px; border-width: 1px}
  .compLDD { width: 100%; padding: 12px 10px 16px; border-top: 1px solid #ddd;}
  .compLDT:last-of-type { border-bottom:none} .compLDD:last-of-type { border-bottom: 1px solid #3e77cc; } }

@media (max-width: 480px) { .TMessageCopy { font-size: 1.5rem} }

/* Access */
#accDetail { margin: 50px auto 0; padding-bottom: 20px}

.accMeta { width: 350px; padding-left: 15px; position: relative}

.accessCopy { font-size: 1.5rem; line-height: 2; letter-spacing: .06em; margin: 0}
.accessCopy br { display: none}

.aCCKind { font-size: 1.6rem}

.accTelNum { font-size: 1.6rem; font-style: normal; display: block}

.accLink { color: #333; text-decoration: none; vertical-align: -.04em; padding-left: 15px; cursor: pointer; position: relative; overflow: hidden}
.accLink:hover { color: #1e8eb7}

.accTmark { position: absolute; top: 7px; left: 0;
  background-position: -160px -30px; width: 12px; height: 14px; display: inline-block}

.accPhoto {
  position: absolute; bottom: 0; left: 0;
  width: 100%; height: auto; min-height: 270px}

.mapContainer { width: calc(100% - 390px); border: 1px solid #bbb}

#GMap, #GMap02 { background: #d4eef9; height: 40vw; min-height: 388px; margin: 0}

@media (max-width: 859px) {
  .accMeta { width: 260px} .mapContainer { width: calc(100% - 310px)}
  .accessCopy .spBlock { display: block} .accPhoto { min-height: inherit} }

@media (max-width: 767px) {
  .accMeta { padding: 0} #accDetail { margin-top: 30px} .accMeta, .mapContainer { width: 100%}
  .accessCopy br { display: block} .accessCopy .spBlock { display: inline} .accTelNum { display: inline}
  .accPhoto { width: 70%; max-width: 420px; margin: 20px auto 0; position: relative}
  .mapContainer { margin-top: 30px} #GMap, #GMap02 { min-height: 320px} }

@media (max-width: 640px) { #GMap, #GMap02 { height: 50vw; min-height: 320px} }

@media (max-width: 540px) { .accPhoto { width: 100%;}}
@media (max-width: 500px) { .accPhoto { max-width: none}}

@media (max-width: 480px) { #GMap, #GMap02 { height: 80vw; min-height: 320px} }
@media (max-width: 420px) { .accessCopy br { display: none} .accessCopy .spBlock { display: block} }

/* -------------------------------------------
  PHILOSOPHY
------------------------------------------- */
#philosophyContents { padding-bottom: 60px}
.philoSec01, .philoSec02 { display: block;}
.philoSec02 { margin-top: 80px}

.philoST { font-size: clamp(3rem, 4vw, 3.4rem); padding-top: 9px}

#PSTJP01 .onChar6 { margin: 0 -2px 0 -5px}
#PSTJP01 .onChar8, #PSTJP02 .onChar7 { margin: 0 -3px}
#PSTJP11 .onChar5, #PSTJP02 .onChar9, #PSTJP33 .onChar5 { margin: 0 6px}
#PSTJP11 .onChar8 { font-size: clamp(2.6rem, 3.6vw, 3rem); margin: 0 -6px}
#PSTJP03 .onChar7 { margin-left: -5px}
#PSTJP03 .onChar13 { margin-right: -2px}

#PSTJP11 .onChar5 { margin: 0 .25em;}

.philoCopy { color: #555; font-size: 1.6rem; line-height: 2.8; letter-spacing: .06em; margin: 35px 0 0 15px}

#philoCopy03 { line-height: 2.4}

.philoKindIM, .PKIM02 { width: 60%; min-width: 300px; height: auto; margin: 4vw auto 0; display: block}
.PKIM { width: 100%; height: auto}

@media (min-width: 800px) { .philoCopy { margin-left: 10vw} }
@media (min-width: 700px) and (max-width: 799px) { .philoCopy { margin-left: 6vw} }
@media (max-width: 767px) { .philoSec02 { margin-top: 60px}}
@media (max-width: 699px) { .philoCopy { margin-top: 30px} }

@media (max-width: 669px) {
  #philoCopy02, #philoCopy03 { margin-top: 22px}
  .philoCopy .spBlock01, .philoCopy .spBlock02, .philoCopy .spBlock03 { line-height: 1.8; margin-bottom: -1.5em; display: block}
  .philoCopy .spBlock01 { margin-left: 1em} .philoCopy .spBlock02 { margin-left: 1.4em} .philoKindIM, .PKIM02 { margin-top: 60px}
 .philoCopy .spMB01 { margin-bottom: -1.8em} }

@media (max-width: 480px) { 
  #philoST01, #philoST03 { padding: 4px 16px 12px 13px} #PSTJP01, #PSTJP03 { line-height: 1.3; display: inline-block}
  #PSTJP01 { width: 5em} #PSTJP11, #PSTJP33 { margin-top: 5px; display: block}
  #PSTJP11 .onChar5,  #PSTJP33 .onChar5 { margin-left: 3px} #PSTJP03{ width: 8.3em} }

@media (max-width: 430px) { .philoCopy { margin-left: 0} }
@media (max-width: 420px) { .philoKindIM, .PKIM02 { width: 90%;} }
@media (max-width: 370px) { .philoST { font-size: 2.8rem} }

/* -------------------------------------------
  WORKS
------------------------------------------- */
#worksCat { align-items: start}

#worksCatST { font-size: 3.4rem; letter-spacing: .065em; width: fit-content; margin: 0; padding-bottom: 8px}

/* Works Category Navi */
#worksCatNav { width: calc(100% - 350px); padding-right: 5vw}

.WCNList {
  display: -webkit-flex; display: flex; -webkit-justify-content: space-around; justify-content: space-around;
  -webkit-flex-flow: row; flex-flow: row; margin: 0; padding: 6px 0 0}

.WCItem { font-size: 1.8rem; letter-spacing: .1em; text-indent: .1em; margin: 0; padding: 10px 15px 16px; position: relative}

.WCLink { color: #444; text-decoration: none; display: block}

.WCLSign {
  content: ''; position: absolute; bottom: 0; left: 50%;
  background: #1e7ecc; width: 10px; height: 8px; margin-left: -5px; clip-path: polygon(0 0, 100% 0, 50% 100%)}

@media (max-width: 767px) {
  #worksCatNav { width: 100%; margin-top: 14px; padding: 0} .WCItem { font-size: 1.6rem} #worksCatWrapp { padding-bottom: 40px} }

@media (max-width: 480px) { .WCNList { justify-content: space-between; justify-content: space-between} }

/* Works List */
#worksWrapp { padding-bottom: 50px}

#worksList .TWLItem:nth-child(n+4) { margin-top: 45px}

@media (max-width: 767px) { #worksList .TWLItem:nth-child(n+3) { margin-top: 45px}}

/* Works Category List */
#worksCatName { justify-content: flex-start}

#worksCatNameST { font-size: 2.2rem; letter-spacing: .05em; margin: 16px 0 0}
#worksCatNameST .onChar13 { width: 10px}
#worksCatNameST .onChar14 { font-weight: 500 !important}

#worksCatTit {
  font-size: 3.2rem; letter-spacing: .1em; width: fit-content; margin: 0 0 0 15px; padding: 7px 10px 15px 10px;
  overflow: visible; position: relative}

@media (max-width: 600px) {
  #worksCatName { display: block} #worksCatNameST { font-size: 1.6rem; font-weight: 600 !important; margin: 0;}
  #worksCatNameST .onChar13, #worksCatNameST .onChar14 { display: none}
  #worksCatTit { font-size: 2.8rem; margin: 10px 0 0} }

/* Works Individual */
.WIndMeta { max-width: 980px; margin: 0 auto;}

.WIndClientName { font-size: clamp(2rem,5vw,2.8rem); line-height: 1.6; letter-spacing: .06em; margin: 0;}

.WIndData { width: 100%; margin: 40px auto 0; padding: 0; border-bottom: 1px solid #bbb;}
.WIkind, .DIInfo {
  color: #555; font-size: 1.6rem; line-height: 1.75; letter-spacing: .06em; margin: 0; padding: 1em 10px; border-top: 1px solid #bbb}
.WIkind { width: 6em}
.DIInfo { width: calc(100% - calc(7.8em + 20px)) }

.WIMainImage { width: 100%; margin: 55px auto 0}

.indIMGallery { width: 100%; margin: 0 auto; position: relative}

.indGItem { width: 47.5%; margin-top: 5%}
.IGIM { width: 100%; height: auto}

@media (max-width: 560px) {
  .WIkind { width: 5.5em; padding-right: 0;} .DIInfo { width: calc(100% - calc(5.5em + 20px)); padding-left: 0}
  .DIInfo::before{ content: "： "} #DIDetail::before{ content: ''}
  #WIInfo { width: 100%; padding-bottom: 0} #WIInfo::after { content: " ："}
  #DIDetail { width: calc(100% - 20px); padding: 10px 10px 1.2em; border-top: none} }

@media (max-width: 499px) { .WIMainImage, .indGItem { width: 100%; max-width: 420px} .indGItem {margin: 5% auto 0} }

@media (max-width: 480px) { .WIkind, .DIInfo { font-size: 1.5rem} }

/* -------------------------------------------
  RECRUIT
------------------------------------------- */
.recruitWrapp { margin-top: 90px; padding-bottom: 20px;}
.recruitWrapp:first-of-type { margin-top: 30px}

#newGraduatesInfo { font-size: 1.7rem; padding: 30px 0 15px !important;}

.recJobType { font-size: 1.8rem; font-weight: 600; letter-spacing: .06em; margin: 0}
.JTypeST { background: #cce2f5; padding: 7px 9px 9px; display: inline-block; position: relative}
.JTKind { background: #1e7ecc; color: #fff; margin-left: 26px; padding: 7px 12px 9px 12px; display: inline-block}

.JTypeST::after {
  content: ">"; position: absolute; top: 50%; right: -22px; color: #1e7ecc; font-size: 2.4rem; font-weight: 700;
  display: block; -webkit-transform: translateY(-.5em) scaleX(.75); transform: translateY(-.5.5em) scaleX(.75)}

.recList { margin: 35px auto 0; padding: 5px 0; border-top: 1px solid #ccc; border-bottom: 1px solid #ccc}

.recLDT, .recLDD { font-size: 1.6rem; font-weight: 500; line-height: 1.75; letter-spacing: .06em; margin: 0; padding: 18px 15px}
.recLDT { width: calc(6em + 3px)}
.recLDD { width: calc(100% - 7em - 52px)}

.recLDT:nth-of-type(odd), .recLDD:nth-of-type(odd) { background: #e9e9e9}

@media (max-width: 640px) {
  .recLDD br, .recLDD .spNFalse{ display: none} .recLDD .spNBrake::before { content: "、"}
  .JTypeST::after { right: -28px; -webkit-transform: translateY(-.4em) scale(1,.8) rotate(90deg);
    transform: translateY(-.4em) scale(1,.8) rotate(90deg)}
  .JTKind { margin: 15px 0 0; display: block} .recJobType .spNSmall { font-size: 1.4rem; margin-right: -.3em} }
@media (max-width: 599px) {  .recruitWrapp:first-of-type { margin-top: 20px} }

@media (max-width: 559px) {
  #newGraduatesInfo { font-size: 1.6rem; line-height: 1.8; padding: 15px 0 0 !important}
  .recLDT, .recLDD { width: 100%; display: block} .recLDT { padding: 16px 15px 0} .recLDT::after{ content: "："}
  .recLDD { padding: 2px 15px 16px 31px} }

@media (max-width: 450px) { .recJobType { font-size: 1.7rem} .recLDT, .recLDD { font-size: 1.5rem} }

@media (max-width: 420px) { .JTKind { display: inline-block} .JTKind .spNBlock { margin-top: 8px; display: block} }

/* -------------------------------------------
 NEWS
------------------------------------------- */
/* News List */
.newsWrapp { padding: 0 5vw 35px}

.newsList { margin: 0 auto; position: relative}

.NLLink {
  text-decoration: none; padding: 45px 15px; border-bottom: 1px solid #bbb;
  display: block; position: relative; z-index: 1; cursor: pointer; overflow: hidden}
.NLLink:first-of-type { padding-top: 50px}
.NLLink::after {
  content: ''; position: absolute; top: 0; left: 0; right: auto; background: #e2f2fa; width: 0; height: 100%; z-index: -1}

.NLTit { align-items: center; color: #333; font-size: 1.7rem; line-height: 1.8; letter-spacing: .06em; margin: 0}

.NLTime { color: #7e7e7e; letter-spacing: .1em; width: 110px}

.NLCopy { width: calc(100% - 190px); padding-right: 40px;}

.NLSign {
  position: absolute; top: 50%; right: 15px;
  background: #bbb; width: 18px; height: 18px; margin-top: -9px; display: block}

.NLSign::before, .NLSign::after { content: ''; position: absolute; top: 50%; background: #fff; height: 1px}
.NLSign::before { left: 4px; width: 10px}
.NLSign::after { right: 4px; width: 4px; margin-top: -2px; -webkit-transform: rotate(45deg); transform: rotate(45deg)}

@media (max-width: 767px) {
  .NLLink { padding: 35px 10px} .NLLink:first-of-type { padding-top: 35px} .NLSign { right: 10px}
  .NLTit, .NLTime, .NLCopy { display: block}
  .NLTime { font-size: 1.5rem; width: 70%} .NLCopy { font-size: 1.6rem; width: calc(100% - 2em)} }

@media (max-width: 480px) { .NLLink { padding: 35px 0} .NLSign { right: 0} .NLTime { font-size: 1.4rem} }

/* News Post */
.newsArticle { padding-top: 50px}

.newsAHead { padding-bottom: 60px; border-bottom: 1px solid #bbb}

.newsTitle { font-size: clamp(2.2rem,5.8vw,2.5rem); line-height: 1.6; letter-spacing: .05em; margin: 0}

.newsTime { color: #777; font-size: clamp(1.4rem,4vw,1.6rem); letter-spacing: .08em; margin-top: 12px; display: block}

.newsBody { padding-top: 20px}

.newsBody p, .newsBody li { font-size: 1.6rem; line-height: 2.5; 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 0; padding-bottom: 7px; border-bottom: 2px solid #ccc; display: inline-block}
.newsBody h3 { font-size: 2rem}
.newsBody h4 { font-size: 1.8rem; margin-bottom: 1.1em}
.newsBody h5 { font-size: 1.7rem; margin-bottom: 1.1em}
.newsBody ul { margin: 0; padding: 0 0 0 36px}
.newsBody li { margin: 0; list-style-type: circle}

.newsBody img { width: 100% !important; max-width: 1000px; height: auto !important; margin: 0 auto; padding: 10px 0; display: block}
.newsBody a img { text-decoration: none; border: none; outline: none}

/* CMS List Navigation */
#CMSPagination { padding: 40px 5vw 30px; border-top: 1px solid #bbb}

#newsPageNavi { padding-top: 45px;}

#paginationList { text-align: center; margin: 0 auto; padding: 0 7px 0 0}

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

.link_page, .current_page { width: 40px; height: 40px; margin-top: 5px; display: block; position: relative; z-index: 1}

.link_page:before, .link_page: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:before { background: #399eb5; z-index: -2}
#paginationList .current_page:before { background: #b5b5b5; z-index: -1}

#paginationList .link_page:after {
  background: #00c2cc; -webkit-transform: scale(0); transform: scale(0); z-index: -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)}

/* Individual Pagination */
.CMSIndNavi { margin: 0 auto; padding: 4px; border-top: 1px solid #bbb; position: relative}

.indPageNavi { margin: 0; padding: 0}

.indPageNavi a {
 color: #555; font-size: 1.5rem; text-align: center; letter-spacing: .1em; text-decoration: none;
 padding: 32px 0; display: block; position: relative; z-index: 1}

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

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

.RLSign { top: inherit; bottom: 12px; 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; }

@media (max-width: 699px) { .PESign { left: 10%} .NESign { right: 10%} }

@media (max-width: 560px) { .indPageNavi a { font-size: 1.4rem; letter-spacing: .06em}}
@media (max-width: 480px) {
  .indPageNavi a { padding: 20px 0 32px} .returnList .spFalse { display: none}
  .PESign, .NESign { top: inherit; bottom: 18px; left: 50%; background: #555; width: 26px; margin-left: -12px}
  .RLSign { left: calc(50% - 15px); bottom: 12px; width: 30px} .returnList a .RLSign:after { width: 12px; height: 8px}
  .returnList a .RLSign:before { left: 12px; bottom: 8px} }

/* -------------------------------------------
  Contact Page
------------------------------------------- */
#contact { padding-top: 60px}

#contactHead { margin: 0 auto; padding: 50px 5vw}
#contactHead { padding-top: 0}

.telephoneContact, #contactForm { max-width: calc(800px - 10vw); margin: 0 auto}

.telConInner { align-items: center; max-width: 440px; margin: 0 auto}

.telConCopy { font-size: 1.7rem; letter-spacing: .075em; width: 140px; margin: 40px 0 0; padding-top: 7px}

#contactForm { background: #fff; margin: 0 auto; position: relative}

.contactST { color: #555; font-size: 3.2rem; letter-spacing: .05em; margin: 0}

.telephoneNum { font-size: 3.6rem; font-weight: 600; letter-spacing: .04em; width: 280px; margin: 40px 0 0}

.telephoneLink { color: #1e7ecc; text-decoration: none; padding-left: 25px; display: inline-block; position: relative}

.telMark {
  position: absolute; top: 10px; left: 0; background: url(../contact/images/tel_mark.svg) no-repeat 0 0 / 20px 24px;
  width: 20px; height: 24px; display: block; opacity: .8}

@media (max-width: 540px) {
  .telephoneNum { font-size: 3.2rem} .telConCopy { padding-top: 7px}
  .telMark { top: 8px; background-size: 18px 22px; width: 18px; height: 22px} .telephoneLink { padding-left: 22px} }

  @media (max-width: 480px) {
    .telephoneContact { padding-bottom: 50px;} .telConInner { text-align: center; display: block}
    .telConCopy, .telephoneNum { width: 100%; margin-top: 20px; display: inline-block} }

/* Contact Main */
.contactForm { margin-top: 10px}

/* Progress Area */
.formProgress { width: 56%; min-height: 65px; margin: 0 auto; padding: 0; position: relative}

.formProgress:before {
  content: ''; position: absolute; top: 46px; left: 50%;
  background: #ccc; width: 176%; height: 1px; margin-left: -88%}

@media (max-width: 500px) { .formProgress { width: 70%} .formProgress:before { width: 140%; margin-left: -70%}}
@media (max-width: 410px) { .formProgress { width: 80%} .formProgress:before { width: 124%; margin-left: -62%} }

#FPInput, #FPConfirm, #FPCompletion {
  color: #7e7e7e; font-size: 1.6rem; font-weight: bold; text-align: center; letter-spacing: .4em; text-indent: .25em; width: 60px; position: relative}
#FPInput { text-indent: .45em}

#FPInput::before, #FPConfirm::before {
  content: ''; position: absolute; top: 35px; left: 20px; width: 0; height: 0; border-style: solid;
  border-width: 12px 0 12px 20px; border-color: transparent transparent transparent #aeaeae}
#FPCompletion::before {
  content: ''; position: absolute; top: 36px; left: 19px; width: 20px; height: 20px;
  background: #aeaeae; -webkit-border-radius: 50%; border-radius: 50%}

#FPInput.FPOnPhase::before, #FPConfirm.FPOnPhase::before {
  top: 32px; left: 12px; border-width: 30px 18px 0 18px;
  border-color: #33b3d0 transparent transparent transparent}
#FPInput.FPOnPhase::after, #FPConfirm.FPOnPhase::after {
  content: ''; position: absolute; top: 38px; left: 22px; width: 0; height: 0; border-style: solid;
  border-width: 14px 8px 0 8px; border-color: #fff transparent transparent transparent}

#FPCompletion.FPOnPhase::before { top: 32px; left: 14px; background: #33b3d0; width: 30px; height: 30px}

#formNotice { font-size: 1.6rem; letter-spacing: .06em; margin: 30px 0 0; padding-left: 90px; position: relative}

#formNotice::before, .required::before, #MFConsent::before {
  content: ''; position: absolute; top: 2px; width: 10px; height: 5px;
  border-left: 2px solid #f0521e; border-bottom: 2px solid #f0521e; -webkit-transform: rotate(-50deg); transform: rotate(-50deg)}
#formNotice::before { left: 70px} .required::before { left: 0}
#MFConsent::before { top: 41px; left: 8px}

@media (max-width: 960px) {
  #FPInput, #FPConfirm, #FPCompletion { font-size: 1.5rem} #FPInput:before, #FPConfirm:before { top: 35px}
  #FPCompletion:before { top: 36px} #FPInput.FPOnPhase:before, #FPConfirm.FPOnPhase:before { top: 32px}
  #FPInput.FPOnPhase::after, #FPConfirm.FPOnPhase::after { top: 38px}
  #formNotice { font-size: 1.4rem; padding-left: 16px}
  #formNotice:before, .required:before, #MFConsent:before { top: 3px}
  #formNotice:before { left: 0} #MFConsent:before { top: 38px; left: 50%; margin-left: -16.1em} }

@media (max-width: 480px) { #formNotice .spFalse { display: none !important} }
@media (max-width: 369px) { .SPF02 { display: none} }

/* Form Area */
#formContents { margin-top: 35px}
#mfp_hidden { display: none}

.MFItem { margin: 30px 0 0; position: relative}

.required, .optional { font-size: 1.5rem; letter-spacing: .06em; text-indent: 18px}

.optional:before {
  content: ''; position: absolute; top: 2px; left: 0; background: #ccc; width: 12px; height: 12px}

.MFIKind { font-style: normal; display: block}

.MFNotice { color: #006eb2; font-size: 1.3rem; letter-spacing: .05em; margin: 8px 0 0 10px; display: block;}

.MFSelect, .inp01, .mail, textarea {
  color: #006eb2; font-size: 1.5rem; letter-spacing: .06em; padding: 8px; margin-top: 10px;
  border: none; outline: none; vertical-align: .2em; border: 2px solid #ccc; -webkit-appearance: none; appearance: none}
.MFSelect { width: 14em; -webkit-border-radius: 5px; border-radius: 5px}
.inp01, .mail { width: 85%}

@media (min-width: 740px) { .inp01, .mail { width: 70%}}

textarea {
  font-size: 1.8rem !important; line-height: 1.8; letter-spacing: .08em !important;
  width: calc(100% - 34px); height: 15em !important; padding: 10px 15px}

.inp01, #contactContents { -webkit-appearance: none;appearance: none }
::-webkit-input-placeholder { color:#888} :-ms-input-placeholder { color:#888} ::placeholder{ color:#888}
::placeholder {font-size: 1.5rem} input::-webkit-input-placeholder {font-size: 1.5rem} input:-moz-placeholder {font-size: 1.5rem}
input::-moz-placeholder {font-size: 1.5rem} input:-ms-input-placeholder {font-size: 1.5rem}

#MFConsent {
  text-align: center; letter-spacing: .025em; margin: 0 auto; padding-top: 35px; position: relative}

#consent { margin: 0 6px 0 5px; vertical-align: 3px}

#consentLabel { color: #82694e; font-weight: bold; letter-spacing: 0; text-indent: 0; display: block; position: relative; z-index: 1; cursor: pointer}

#MFBTArea { padding-top: 52px; position: relative}

.TFSend, #MFContainer p.TFReset { text-align: center; margin: 0; padding: 0; border: none}

.mfp_element_button {
  font-size: 1.6rem; line-height: 2; letter-spacing: .1em;
  width: calc(50% - 15px); text-transform: uppercase; padding: 5px 0 6px 1px;
  position: relative; border: none; outline: none; cursor: pointer; -webkit-appearance: none; appearance: none}

#sendBT {
  color: #fff; background: #4985bb; font-size: 1.6rem; font-weight: bold; letter-spacing: .1em;
  width: calc(100% - 40px); margin: 0 auto; padding: 12px 0 12px 1px; border: none;
  border-radius: 4px; position: relative; display: block}
#sendMessage { display: none}

#mfp_button_send, #mfp_button_cancel { color: #fff; font-weight: bold; border-radius: 4px}
#mfp_button_send { background: #4985bb}
#mfp_button_cancel { background-color: #777}

#sendBT, #mfp_button_send, #mfp_button_cancel { -webkit-appearance: none; appearance: none}

@media (max-width: 400px) { .MFSelect { width: 90%}}
@media (max-width: 365px) { #spConsent .spNFalse { display: none} }
@media (max-width: 359px) {
  #MFConsent .required { font-size: 1.4rem; letter-spacing: 0} #MFConsent:before { top: 37px; margin-left: -149px} }
@media (max-width: 350px) { #formNotice:before { top: 4px}}
@media (max-width: 340px) { .inp01, .mail { width: calc(100% - 20px)} .mfp_element_button { width: calc(50% - 10px)}}

@media (min-width: 480px) { #sendBT { max-width: 360px}}
@media (min-width: 640px) { .mfp_element_button { width: calc(48% - 15px)}}

/* Form Privacy */
.formPrivacy { height: 180px; margin: 30px 0 0; padding: 20px 0; border: 1px solid #ccc; position: relative; overflow: hidden}

.FPInner {  height: 100%; padding: 0 15px; position: relative;-webkit-overflow-scrolling: touch; overflow-y: auto}
.FPTitle {
  color: #82694e; font-size: 1.6rem; font-weight: bold; text-align: center; letter-spacing: .1em; margin: 0 0 10px}

#FPList dt, #FPList dd, .formPrivacy p { font-size: 1.4rem; letter-spacing: .06em; line-height: 1.8; padding: 0}
#FPList dt { font-weight: bold; margin: 15px 0 0} #FPList dd { font-size: 1.3rem; margin: 0; padding: 3px 0 0}
#FPList ul { margin: 0; padding: 0 0 0 2.5em} #FPList li { list-style-type: circle}
.formPrivacy p { color: #82694e; font-weight: bold; margin: 0}

@media (max-width: 479px) { .FPTitle .spNFalse { display: none}}

/* Checkbox */
.repItem, .mfp_element_hidden { display: none}

.repItem[type='checkbox'] { position: absolute; visibility: hidden !important}

.repItem[type='checkbox'] + label:before, .repItem[type='checkbox'] + label:after,
.repItem[type='checkbox'] + .mfp_element_hidden[type='hidden'] + label:before,
.repItem[type='checkbox'] + .mfp_element_hidden[type='hidden'] + label:after {
  content: ''; position: absolute; left: 50%;
  -webkit-box-sizing: border-box; box-sizing: border-box; -webkit-transform: rotate(0); transform: rotate(0)}

.repItem[type='checkbox'] + label:before,
.repItem[type='checkbox'] + .mfp_element_hidden[type='hidden'] + label:before {
  top: 29px; background: #fff; width: 40px; height: 20px; margin-left: -20px;
  border: 1px solid #92a2b2; -webkit-border-radius: 15px; border-radius: 15px; }

.repItem[type='checkbox'] + label:after,
.repItem[type='checkbox'] + .mfp_element_hidden[type='hidden'] + label:after {
  top: 30px; background: #92a2b2; width: 18px; height: 18px; margin-left: -19px;
  -webkit-transition: all .2s ease-out; transition: all .2s ease-out;
  -webkit-border-radius: 50%; border-radius: 50%; z-index: 10}

.repItem[type='checkbox']:checked + label:after,
.repItem[type='checkbox']:checked + .mfp_element_hidden[type='hidden'] + label:after { background: #00bb0e; margin-left: 1px; }

/* Error Message */
.mfp_err {
  color: #d20; background: url(../contact/images/mfp_error.gif) no-repeat 0 15px; font-size: 1.4rem; text-align: left;
  line-height: 1.2; letter-spacing: .025em; margin: 0; padding-top: 15px; clear: both; display: none}

#MFConsent .mfp_err { margin-top: 32px; padding-left: 20px}

.mfp_parent_error { border: solid 2px #f00}

.problem { background-color: #fCC}

#mfp_error {  background-color: #fee; padding: 10px; border: solid 1px #f00; display: none}
#mfp_error p { font-size: 1.4rem; text-align: center; padding: 0; margin: 0}
#mfp_error p strong { color: #d20; font-size: 1.8rem}

/* SSL Info */
#siteSsl { margin: 35px auto 0; padding-top: 18px; border-top: 1px solid #ddd; display: block}

.sslInfo { font-size: 1.3rem; line-height: 1.5; letter-spacing: .05em; margin: 0}

@media (min-width: 640px) { .sslInfo .spWBlock { display: block} }

@media (min-width: 460px) {  .sslInfo { text-align: center;} .sslInfo .spBlock { display: block;}}

/* Confirm */
#mfp_phase_confirm h4 { color: #f26500; font-size: 2rem; text-align: center; letter-spacing: .1em; margin: 25px 0 0}

#mfp_confirm_table { width: 100%; margin: 30px 0 0; border: none; border-spacing: 1px; border-bottom: 1px solid #ddd}

#mfp_confirm_table th, #mfp_confirm_table td {
  font-size: 1.5rem; line-height: 1.5; letter-spacing: .06em; display: block}
#mfp_confirm_table th { color: #4e4e4e; text-align: left; padding: 12px 20px 0; vertical-align: top}
#mfp_confirm_table td { color: #00597e; padding: 6px 20px 12px}

#mfp_confirm_table tr:nth-of-type(odd) th, #mfp_confirm_table tr:nth-of-type(odd) td { background: #f5f5f5}

.mfp_buttons { margin: 30px auto} #mfp_button_send, #mfp_button_cancel { width: 47.25%}

@media (min-width: 560px) { #mfp_confirm_table td { padding-left: 30px}}

/* completion */
#completion { padding-bottom: 10px}

#completionBCList { padding-bottom: 18px}

#completionST { color: #1e7ecc; font-size: clamp(2.4rem,5.4vw,3.2rem); text-align: center; letter-spacing: .1em; margin: 40px 0 0}

.completionInfo { font-size: 1.6rem; line-height: 2; letter-spacing: .06em; margin: 40px 0 0; padding: 0 40px}
.completionInfo > .PPad12 { padding-top: 12px; display: block}

@media (min-width: 600px) { #completionWrapp { padding-top: 30px}}
@media (min-width: 700px) { #completionWrapp { padding-top: 45px}}
@media (max-width: 699px) { .completionInfo { padding: 0} }
@media (max-width: 599px) { #completionWrapp { padding-top: 20px} }
@media (max-width: 480px) { .completionInfo { font-size: 1.5rem}}

/* ----------------------------------------
  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}


/* -------------------------------------------
 CSS Animation
------------------------------------------- */
/* Common Animation */
.GNLink, .GNLink::after, #botLogo, #retTop::after, #retTop a::after, .ANInstaLink, .FNInstaLink, .ORInstaLink,
.BreadcrumbList a::after, .sign01, .TALCap, .WCLink, .WCLSign, .BAITLink, .BATMark, .TALName, .TWLName, .TWClient, .telephoneLink, .telMark,
.TWKind, .WKind, .TNNLink, .TNNLink::after, .NLLink::after, .NLTit, .link_before, .link_next, .previousEntry a, .returnList a, .nextEntry a {
  -webkit-transition: all .15s ease-in-out .05s; transition: all .15s ease-in-out .05s}

#globalHead, .homeLink, #GNav, #trigger-overlay::before, #trigger-overlay::after, .FNLink::after, .ONItem a::before,
.TALImage::before, .TWLImage::before, .LBT01, #retTop::before, .LBT01::after,
.previousEntry a:before, .returnList a:before, .nextEntry a:before, .previousEntry a:after, .returnList a:after, .nextEntry a:after,
.RLSign, .PESign, .NESign, #mfp_button_send, #mfp_button_cancel {
 -webkit-transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s; transition: all .35s cubic-bezier(.075, .82, .165, 1) .05s}

.link_page:before, .link_page:after, .link_before, .link_next { -webkit-transition: all .2s ease-in-out .1s; transition: all .2s ease-in-out .1s}

.TWLIM, .NLSign { -webkit-transition: all .25s ease-in-out .05s; transition: all .25s ease-in-out .05s}


/* 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}

@-webkit-keyframes leftIn {
  0%,25%{ -webkit-transform: translate3d(-30px,10px,0); opacity: 0} 100%{ -webkit-transform:none; opacity: 1} }
@keyframes leftIn { 0%,25%{ transform: translate3d(-30px,10px,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,10px,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 { -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 .8s cubic-bezier(.62,-0.02,.22,.88); animation: scaleUp .8s cubic-bezier(.62,-0.02,.22,.88);
  -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%,50%{-webkit-transform:translate3d(-10px,-10px,0);opacity:0} 100%{-webkit-transform:none;opacity:1}}
@keyframes typing01 {0%,50%{transform:translate3d(-10px,10px,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%,70%{-webkit-transform:translate3d(-8px,8px,0);opacity:0} 100%{-webkit-transform:none;opacity:1}}
@keyframes movTyping {0%,70%{transform:translate3d(-8px,8px,0);opacity:0} 100%{transform:none;opacity:1}}
.movType .onChar1{display:inline-block;-webkit-animation:movTyping .8s ease;animation:movTyping .8s ease}.movType .onChar2{display:inline-block;-webkit-animation:movTyping .9s ease;animation:movTyping .9s ease}.movType .onChar3{display:inline-block;-webkit-animation:movTyping 1s ease;animation:movTyping 1s ease}.movType .onChar4{display:inline-block;-webkit-animation:movTyping 1.1s ease;animation:movTyping 1.1s ease}.movType .onChar5{display:inline-block;-webkit-animation:movTyping 1.2s ease;animation:movTyping 1.2s ease}.movType .onChar6{display:inline-block;-webkit-animation:movTyping 1.2s ease;animation:movTyping 1.2s ease}.movType .onChar7{display:inline-block;-webkit-animation:movTyping 1.3s ease;animation:movTyping 1.3s ease}.movType .onChar8{display:inline-block;-webkit-animation:movTyping 1.9s ease;animation:movTyping 1.9s ease}.movType .onChar9{display:inline-block;-webkit-animation:movTyping 2.1s ease;animation:movTyping 2.1s ease}.movType .onChar10{display:inline-block;-webkit-animation:movTyping 2.5s ease;animation:movTyping 2.5s ease}.movType .onChar11{display:inline-block;-webkit-animation:movTyping 2.9s ease;animation:movTyping 2.9s ease}.movType .onChar12{display:inline-block;-webkit-animation:movTyping 3.3s ease;animation:movTyping 3.3s ease}.movType .onChar13{display:inline-block;-webkit-animation:movTyping 2.8s ease;animation:movTyping 2.8s ease}.movType .onChar14{display:inline-block;-webkit-animation:movTyping 3.7s ease;animation:movTyping 3.7s 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, .DIInfo a { color: #1e8eb7; text-decoration: none; display: inline-block; position: relative}
.tLink01:hover, .newsBody p a:hover { color: #f07700}
.FNLink:hover { color: #5ec9e5}

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

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

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

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

#globalNav .current { cursor: default}
