@media print {
  html { font-size: 13px; }
  .hide-1200 { display: none !important;}
  .show-1200 { display: block !important; }
	.inner1500,
  .inner1300,
  .inner1100{ width: calc(100% - 80px);}

  #header { width: 100%; height: 100px; padding: 0 40px; background: #fff; position: inherit; z-index: 9999; }
  .linkanchor { padding-top: 120px; margin-top: -120px; }
  main { padding-top: 100px; }
  .logo { }
  .sp-headicoul { display: none;}
  #g-nav,
  #g-nav-list,
  #g-nav-list > div,
  #g-nav-list ul,
  #g-nav-list ul li { display: flex; align-items: center; height: 100%; }
  #g-nav-list .noto { font-weight: 500;}
  .headmenuul { }
  .headmenuul li { }
  .headmenuul > li > a { height: 100%; padding: 0 20px; border-bottom: none !important; }
  .headmenuul > li > a:hover,
  .headmenuul > li:has(.dropdown:hover) > a { background: #E71F19; color: #fff; }
  .dropdown { display: none; position: absolute; top: 100%; left: 0;  width: 100vw; background: #E71F19;}
  li:hover .dropdown { padding: 30px 0; display: block; }
  .dropdownul { margin-left: -10px; margin-bottom: -10px; }
  .dropdownul li { width: calc(100% / 3 - 10px); margin-left: 10px; margin-bottom: 10px; }
  .dropdownul li a { width: 100%; height: 80px; background: #fff; }
  .dropdownul li a:hover { color: #E71F19;}
  .dropdownulimg { overflow: hidden; width: 100px; height: 100%; }
  .dropdownul li a p { width: calc(100% - 100px); padding: 0 15px; font-weight: 700; }
  main { padding-top: 50px; }
  .headbtnul > li > a .headbtnico { width: calc(28px * 0.7); height: calc(28px * 0.7); margin-right: 6px; }
  #header { height: 80px; padding: 0 20px; }
  .logo { width: 200px; }
  .headmenuul { font-size: 16px; }
  .headmenuul > li > a { padding: 0 10px; }
  .headbtnul { margin-left: 10px; }
  .headbtnul > li { margin-left: 10px; }
  .headbtnul > li > a { width: 140px; height: 50px; border-radius: 25px; }
  .headbtnul > li > a p { font-size: 14px; }
  #header { height: 60px; padding: 0 10px; }
  .logo { width: 170px; }
  .headmenuul { font-size: 14px; letter-spacing: 0; }
  .headbtnul > li { margin-left: 6px; }
  .headbtnul > li > a { width: 90px; height: 40px; border-radius: 20px; border-width: 1px; }
  .headbtnul > li > a .headbtnico { width: calc(28px * 0.5); height: calc(28px * 0.5); margin-right: 4px; }
  .headbtnul > li > a p { font-size: 12px; }
  #header{ display: block; }
  .logo { width: 100vw; height: 50px; display: flex; align-items: center; background: #fff; position: fixed; z-index: 99999; }
  .logo a { width: 170px; margin-left: 10px; display: block; }
  .logo a img {  }
  .sp-headicoul { right: 50px; margin-right: 10px; position: fixed; z-index: 99999; display: flex; align-items: center; }
  .sp-headicoul li a { height: 50px; padding: 0 10px; }
  .sp-headicoul li a div { width: 20px;}
  .openbtn { width: 50px; height:50px; right: 0; top: 0; position: fixed; z-index: 99999; background:#E71F19; cursor: pointer;}
  .openbtn span { left: 14px; width: 45%; height: 2px; border-radius: 5px; background: #fff; display: inline-block; transition: all .4s; position: absolute; }
  .openbtn span:nth-of-type(1) { top:13px; }
  .openbtn span:nth-of-type(2) { top:19px; }
  .openbtn span:nth-of-type(3) { top:25px; }
  .openbtn span:nth-of-type(3)::after { top:5px; left:-4px; font-size: 0.8rem; position: absolute; color: #fff; content:"MENU"; }
  .openbtn.active span:nth-of-type(1) { top: 14px; left: 18px; transform: translateY(6px) rotate(-45deg); width: 30%; }
  .openbtn.active span:nth-of-type(2) { opacity: 0; }
  .openbtn.active span:nth-of-type(3) { top: 26px; left: 18px; transform: translateY(-6px) rotate(45deg); width: 30%; }
  .openbtn.active span:nth-of-type(3)::after { top:6px; left: 0; content:"CLOSE"; transform: translateY(0) rotate(-45deg); }
  #g-nav { position:fixed; z-index: 9999; top:0; right: -120%; width:100%; height: 100vh; background:#F0F0F0; transition: all 0.6s; }
  #g-nav.panelactive { right: 0; }
  #g-nav.panelactive #g-nav-list{ padding-top: 50px; position: fixed; z-index: 999; width: 100%; height: 100vh;/*表示する高さ*/ overflow: auto; -webkit-overflow-scrolling: touch; }
  .headmenuul { margin-top: 1px; }
  .headmenuul > li { margin-bottom: 1px; }
  .headmenuul > li > a { height: 50px; padding: 0 20px; background: #E71F19; color: #fff; position: relative; }
  .headmenuul > li > a::before { width: 16px; height: 16px; right: 20px; position: absolute; background: #fff; border-radius: 50%; content: ""; }
  .headmenuul > li > a::after { width: 4px; height: 4px; top: calc(50% - 2px); right: 27px; border-top: 1px solid #E71F19; border-right: 1px solid #E71F19; -webkit-transform: rotate(45deg); transform: rotate(45deg); z-index: 2; content: ""; position: absolute; }
  .dropdown { margin: -1px 0; padding: 20px 0; background: #F0F0F0; }
  .dropdown .inner1500 { width: calc(100% - 40px);}
  .dropdownul { margin-left: -10px; margin-bottom: -10px; }
  .dropdownul li { width: calc(100% / 2 - 10px); margin-left: 10px; margin-bottom: 10px; border-radius: 5px; box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2); }
  .dropdownul li a { width: 100%; height: 60px; background: #fff; }
  .dropdownulimg { overflow: hidden; height: 100%; aspect-ratio: 1 / 1; }
  .dropdownul li a p { width: calc(100% - 60px); padding: 0 10px; line-height: 1.2; font-weight: 500; }
  .dropdownul li a p span { display: inline-block; font-size: 0.8em; margin: 0 0.1em;}
  .headbtnul { width: calc(100% - 40px); margin: 40px auto; display: flex; justify-content: space-between;}
  .headbtnul li { width: calc(50% - 5px); margin: 0; }
  .headbtnul li a { width: 100%; background: #fff; }
  .dropdownul li.compliance p::after,
  .dropdownul li.contractemployee p::after { top: calc(50% - 0.45em); right: 10px; }
  #header .headbtnul { display: block; }
  #header .headbtnul li { width: 100%; margin-bottom: 10px;}
  .foott .line { width: calc(100% - 600px); right: -25vw; }
  .foott .inner1500 { width: calc(100% - 40px); }
  .foott .line {  right: -20vw; }
  .footlogo { width: 60px; }
  .foottname { margin: 0 20px; font-size: 18px;}
  .footbcol:not(:last-child) { padding-bottom: 40px; }
  .footbmid,
  .footbservice,
  .footbcompany{ width: 100%;}
  .indmain .line { top:3vw; width: 45vw; }
  #slider1::before { height: 100%; }
  .indmain .line { top:8vw; }
  .indservicewrap .line { width: calc(100vw - 540px - 40px); }
  .tabwrap{ width: calc(100% + 60px); margin-left: -30px; padding-right: 2px;}
  .tab li { margin: 0 2px; width: calc(100% / 5 - 4px); }
  .tab li a{ padding: 15px 10px; }
  .tabno { width: 50px; height: 24px; border-radius: 12px; font-size: 18px; }
  .tabno.noto { font-size: 14px;}
  .indservicewrap .line { left: 480px; width: calc(100% - 480px + 60px); }
  .custom-pagination { width: calc(50% - 60px); }
  .custom-pagination > div { width: 100%; }
  .indservicesliderwrap { width: 50%; }
  .indserviceslideex > div.flex-aic { padding: 10px; width: 100%; }
  .indserviceslideeximg { width: 30px; margin-right: 10px; }
  .indserviceslideextxt { width: calc(100% - 30px - 10px);}
  .indcompanywrap .line { bottom:85px; right: calc(50vw + 300px); width:calc(50vw - 300px - 30px); }
  .indcompanywrap .line { bottom:80px; right: calc(50vw + 280px); width:calc(50vw - 280px - 30px); }
  .indexwrap .line { right: -100px; }
  .indexwrap .line { top: 30px; right: -80px; width: calc(100vw - 380px); }
  .filtersmid { margin-bottom: 20px; display: block; }
  .filtersmiden { padding-left: 15px; margin-right: 0;}
  .filtersmidjp { padding-left: 25px; margin-top: 5px; }
  .indbnr100bg { width: calc(50% + 5px); }
  .indbnr100txtwrap { width: calc(50% - 5px); min-width: 300px; height: 100%; display: flex; justify-content: center; align-items: center; flex-direction: column; }
  .indbnr100img{ width: 30px; margin-bottom: 10px; margin-right: 0;}
  .indbnr100txt .fs28{ font-size: 18px; }
  .indbnr100txt .indbnrbtn { padding: 0 30px 0 10px; }
  .indblogwrap .line { right: calc(50vw + 80px);width: calc(50vw - 120px); }
  .indrecwrap{ height: 600px;}
  .indrecrad { width: 500px; height: 500px; margin-right: 20px; }
  .indrecmiden { font-size: 70px; }
  .indrecwrap .btn { margin-top: 30px; }
  .line-service-s,
  .line-service-m,
  .line-service-l { right: -100px; }
  .line-service-s,
  .line-service-m,
  .line-service-l { top: 1em; right: -80px; }
  .line-service-s { width: calc(50vw + 120px); }
  .line-service-m { width: calc(50vw - 100px); }
  .line-service-l { width: calc(50vw - 140px); }
  .servicettl03 { max-width: calc(50vw + 100px); }
  .kasou-r { width: calc(100% - 180px); }
  .servicenav { width: 180px; margin-left: -40px; }
  .servicenav > div { padding: 20px 10px 20px 15px; border-radius: 0 10px 10px 0; }
  .servicenavul { padding-left: 15px; }
  .kasoucol { padding-bottom: 80px; }
  .kasou-r {  width: 100%; float: none; }
  .servicenav { padding-top: 20px; width: 100%; float: none; position: relative; top: 0; left: 0; margin: 0; }
  .servicenav > div { padding: 0; background: none; border-radius: 0; }
  .servicenavul { padding-left: 0; border-left: none; display: flex; flex-wrap: wrap; justify-content: space-between; }
  .servicenavul li { width: calc(50% - 1px); margin-bottom: 2px; }
  .servicenavul::after { display: none; }
  .servicenavul li { height: 40px; position: relative; }
  .servicenavul li a { padding: 0 10px; background: #FAD2D1; border-radius: 3px;}
  .servicenavul li a::before { font-size: 12px; position: absolute; right: 10px; font-family: "Font Awesome 6 Free"; font-weight: 900; content: "\f107"; }
  .serviceicoul li { width: calc(50% - 10px);}
  .kasousection .headbtnul li a { border-width: 2px; height: 80px !important; border-radius: 40px !important; }
  .kasousection .headbtnul li a .headbtnico { width: calc(28px * 1.2) !important; height: calc(23px * 1.2) !important; margin-right: calc(8px * 1.2) !important; }
  .kasousection .headbtnul li a p { font-size: 22px !important; }
  .kasousection:not(:last-child) { margin-bottom: 60px; }
  .h2outer { margin-bottom: 30px; }
  .h2outer h2 { padding: 0 5px 15px; }
  .kasousection .headbtnul { width: 100% !important; display: block !important; margin-top: 20px !important;}
  .kasousection .headbtnul li { width: 100% !important; margin: 0 0 10px !important; }
  .kasousection .headbtnul li a { height: 60px !important; border-radius: 30px !important; }
  .kasousection .headbtnul li a .headbtnico { width: 28px !important; height: 23px !important; margin-right: 8px !important; }
  .kasousection .headbtnul li a p { font-size: 18px !important; }
  .serviceicoul { margin-left: -10px; margin-bottom: -10px; }
  .serviceicoul li { width: 100%; height: 60px; padding: 0 10px; }
  .serviceicoulimg { width: 30px; }
  p.serviceicoultxt {  width: calc(100% - 30px - 10px); line-height: 1.3; }
  .serviceprovideulmid { width: 240px; }
  .serviceprovideulmidimg { width: 40px; }
  p.serviceprovideulmidtxt { width: calc(100% - 50px); }
  .serviceprovideultxt { width: calc(100% - 260px); }
  .serviceprovideul {}
  .serviceprovideul li { padding-bottom: 20px; margin-bottom: 15px;}
  .serviceprovideulmid { margin-bottom: 8px; width: 100%; padding-left: 0; }
  .serviceprovideulmidimg { width: 30px; }
  p.serviceprovideulmidtxt { width: calc(100% - 40px); }
  p.serviceprovideulmidtxt br { display: none; }
  .serviceprovideultxt { width: 100%; }
  .servicepriceul { margin-left: -10px; }
  .servicepriceul > li { width: calc(100% / 3 - 10px); margin-left: 10px; }
  .servicepriceulcontent { padding: 20px 15px; }
  .servicepriceulmid h3 { font-size: 20px;}
  .servicepriceuldl dd { padding: 0;}
  .servicepriceulprice span.noto { font-size: 11px;padding: 0 0.15em;}
  .servicepriceulprice span.lex { font-size: 28px; }
  .servicepriceul {  }
  .servicepriceul > li { width: 100%; }
  .servicepriceul > li:not(:last-child) { margin-bottom: 20px; }
  .servicepriceulttl { padding: 8px 16px; height: inherit; }
  .servicepriceulcontent { padding: 20px; }
  .servicepriceulmid { margin-bottom: 20px; }
  .servicepriceulimg { max-width: 120px;margin: 0 auto 30px; }
  .servicepriceuldl dd { margin-bottom: 20px; }
  .serviceex { width: 100%; }
  .servicerelateul li { width: calc(100% / 2 - 20px); }
  .centeryoko:has(.indserviceslidebtn),
  .indserviceslidebtn { width: 100%; }
  .servicecaseul li { padding: 0; }
  .servicecaseul li:not(:last-child) { padding-bottom: 20px; margin-bottom: 20px; }
  .servicecaseul li a::before { width: 24px; height: 24px; bottom: -5px !important; right: 0 !important; }
  .servicecaseul li a::after { right:11px !important; bottom: 4px !important; width: 6px; height: 6px; }
  .servicecaseulimg { width: 200px; }
  .servicecaseultxt { width: calc(100% - 200px - 20px); padding-top: 0; }
  .servicecaseultxt h3 { margin-bottom: 10px; line-height: 1.6; }
  .servicecaseultxt p { -webkit-line-clamp: 2; }


  .kasouttlwrapline { left: 300px; }
  .kasouttlwrapline02 { left: 500px; }
  .kasouttlwrapline::after { width: calc(100vw - 300px); }
  .kasouttlwrapline02::after { width: calc(50vw + 200px); }
  .panwraptsume { }
  .kasouttlwrap{ padding: 4vw 0; }
  .kasouttlwrapline { top: 0.75vw; right: -30px; }
  .kasouttlwrapline02::after { width: calc(50vw + 100px); }

  .rinen01wrap .line { right: 950px; width: calc(50vw - 380px); }
  .rinen01wrap .line { right: calc(50vw + 350px); }
  .rinen02 .inner1100 { padding: 0 100px; }
  .rinen03-limg { width: 40vw; }
  .rinen03-r { width: calc(100% - 40vw); }
  .rinen04wrap .line,
  .historywrap .line {  top:30px; width: calc(100vw - 450px); }
  .profilewrap .line,
  .office01wrap .line { right: calc(50vw + 300px); width: calc(50vw - 350px); }
  .office01maptxt { top: -100px; left: 0; }
  .office01maptxt h3 { font-size: calc(35rem / 17); }
  .office01maptxt p { font-size: calc(18rem / 15); }

  .casenavwrap{  width: 240px; margin-left: -40px; }
  .casenavul { font-size: 14px;}
  .casenavul li a { padding-left: 15px;}
  .kasoucol.flex-jcs .kasou-r{ max-width: calc(100% - 240px); }
  .topic-year-list { font-size: 16px;}
  .topiclist-l { width: 150px; }
  .topiclist-r { width: calc(100% - 150px - 30px); }
  .topiclistwrap { flex-direction: column-reverse; }
  .topiclist-l { width: 100%; margin-top: 40px; }
  .topic-year-list { display: flex; justify-content: space-between; flex-wrap: wrap;}
  .topic-year-list li { width: calc(50% - 1px); margin-bottom: 1px; }
  .topiclist-r { width: 100%; }

  .orgtabwrap { width: calc(200px * 4 + 60px * 3); margin: 60px auto 0; }
  .org { margin-left: 60px; width: 200px;}
  .org.after::after,
  .org.before::before { width: 30px; }
  .orgtab td.after:after {  right: -34px; }
  .orgtab tr:nth-child(1) td[rowspan="7"].before:before { width: calc(200px * 2 + 30px * 5); left: 30px; }
  .orgtab td[rowspan="6"] .org03.after::after {width: calc(200px + 30px * 3); }
  .org02wrap::after { right: -34px;}
  .org02wrap::before { left: 30px; }
  .orgtabwrap { width: calc(100px * 4 + 30px * 3); font-size: 12px; }
  .org { height: 40px; margin-left: 30px; width: 100px; margin-bottom: 5px; }
  .org.after::after,
  .org.before::before { width: 15px; }
  .orgtab td.after:after {  top: 20px; right: -19px; }
  .orgtab td[rowspan="7"].after:after { height: calc(40px * 7 + 5px * 6 - 40px); }
  .orgtab td[rowspan="6"].after:after { height: calc(40px * 6 + 5px * 5 - 40px); }
  .orgtab td[rowspan="2"].after:after { height: calc(40px * 2 + 5px * 1 - 40px); }
  .orgtab tr:nth-child(1) td[rowspan="7"].before:before { top: 23px; height: 4px; width: calc(100px * 2 + 15px * 5); left: 15px; }
  .orgtab td[rowspan="6"] .org03.after::after {width: calc(100px + 15px * 3); }
  .org02wrap::after { height: calc(40px * 5 + 5px * 4 - 20px); top: -47px; right: -19px; }
  .org02wrap::before { height: calc(40px * 9 + 5px * 8); left: 15px; bottom: 20px; }
  .idealimg { width: calc(50% + 25px);}
  .idealcol:nth-child(2n-1) .idealimg { left: -50px; margin-right: -50px; }
  .idealcol:nth-child(2n) .idealimg  { right: -50px; top: -50px; margin-left: -50px; }
  .idealtxt { width: calc(50% - 25px); }
  .idealcol:nth-child(2n-1) .idealtxt { padding-right: 25px; }
  .idealcol:nth-child(2n) .idealtxt { padding-left: 25px; }
  .idealcol:nth-child(2n) .idealimg  {  top: 0; }
  .idealtxt { padding-top: 40px; }
  .idealwrap { margin-top: 40px; }
  .idealwrap .inner1500max { width: calc(100% - 8vw); }
  .idealcol { display: block;}
  .idealimg { aspect-ratio: 2 / 1; margin: 0 !important; left: 0 !important; right: 0 !important; top: 0 !important; width: 100%; overflow: hidden; }
  .idealimg img { object-fit: fit;}
  .idealtxt { padding: 40px 0; width: 100%; }
  .idealcol:last-child .idealtxt { padding-bottom: 0; }
  .trainingwrap { display: block;}
  .trainingcol:nth-child(1) { width: 100%; }
  .trainingcol:nth-child(2) { width: 100%; margin-top: 30px; }
  .trainingmid { height: 60px;}
  .trainingulwrap { padding: 20px; }
  .trainingul {  margin-bottom: -5px; }
  .trainingul li { height: 50px; margin-bottom: 5px; }
  .trainingul.flex-jcs li { width: 100%; }
  .recordtab th { padding: 5px 0 5px 10px;}
  .recordtab td { padding: 10px 0 10px 10px; }
  .recordtab th:nth-child(4),
  .recordtab td:nth-child(4) { text-align: center; }
  .recordtab td:nth-child(5) { padding-left: 10px;}
  .recordtabul { margin-left: -10px;}
  .recordtabul li { margin-left: 10px; }
  .recordtabul li img { width: 22px; height: 22px;}

}