﻿@charset "UTF-8";
/*
layout
*/
/*
color
*/
/*
pxをvwに変換

ウインドウ幅1400pxに対して要素幅50pxの場合
getvw(50,1400)となる
*/
/*
メディアクエリ
記述例
body{
  @include msw('max',1200){
    background-color: red;
  }
}
*/
/*
ICON FONT
*/
/************************************************************
SCREEN ALL
*************************************************************/
/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  .back-btn {
    margin: 60px auto 100px;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  .back-btn {
    margin: 80px auto 150px;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  section.intro .intro-title {
    color: #0C3387;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
    padding-bottom: 13px;
    border-bottom: 1px solid #CED6E7;
  }
  section.intro .intro-title-02 {
    margin-top: 10px;
    color: #0C3387;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 16px;
    font-weight: 700;
    line-height: 2em;
    letter-spacing: 0.05em;
  }
  section.intro .intro-title-03 {
    margin-top: 24px;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.intro .intro-list-01 {
    margin: 10px 0 0 5px;
  }
  section.intro .intro-list-01 li {
    font-feature-settings: "palt" on;
    font-size: 12px;
    font-weight: 400;
    line-height: 2em;
    letter-spacing: 0.98px;
    position: relative;
    padding-left: 1em;
  }
  section.intro .intro-list-01 li::before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0;
  }
  section.intro .intro-list-02 {
    margin: 10px 0 0 0;
  }
  section.intro .intro-list-02 li {
    font-feature-settings: "palt" on;
    font-size: 12px;
    font-weight: 400;
    line-height: 2em;
    letter-spacing: 0.98px;
    position: relative;
    padding-left: 32px;
  }
  section.intro .intro-list-02 li .mark {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 20px;
    height: 2em;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.intro .intro-list-02 li .db {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 1em;
    height: 2em;
    position: absolute;
    top: 0;
    left: 18px;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  section.intro .intro-title {
    color: #0C3387;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
    padding-bottom: 13px;
    border-bottom: 1px solid #CED6E7;
  }
  section.intro .intro-title-02 {
    margin-top: 18px;
    color: #0C3387;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.intro .intro-title-03 {
    margin-top: 24px;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5em;
    letter-spacing: 0.05em;
  }
  section.intro .intro-list-01 {
    margin: 10px 0 0 5px;
  }
  section.intro .intro-list-01 li {
    font-feature-settings: "palt" on;
    font-size: 14px;
    font-weight: 400;
    line-height: 2em;
    letter-spacing: 0.98px;
    position: relative;
    padding-left: 1em;
  }
  section.intro .intro-list-01 li::before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0;
  }
  section.intro .intro-list-02 {
    margin: 10px 0 0 0;
  }
  section.intro .intro-list-02 li {
    font-feature-settings: "palt" on;
    font-size: 14px;
    font-weight: 400;
    line-height: 2em;
    letter-spacing: 0.98px;
    position: relative;
    padding-left: 35px;
  }
  section.intro .intro-list-02 li .mark {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 20px;
    height: 2em;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.intro .intro-list-02 li .db {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 1em;
    height: 2em;
    position: absolute;
    top: 0;
    left: 18px;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
section.table .table-head {
  will-change: transform;
  pointer-events: none;
}
section.table .table-body .table-box {
  font-family: sans-serif !important;
}

.table-last-update {
  margin-top: 20px;
  color: #0C3387;
  leading-trim: both;
  text-edge: cap;
  font-size: 14px;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.05em;
  text-align: right;
}

/************************************************************
SCREEN SP
*************************************************************/
@media screen and (max-width:767px) {
  .table-title {
    padding-top: 30px;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 20px;
    font-weight: 700;
    line-height: 1em;
    letter-spacing: 0.05em;
  }
  section.table {
    margin-top: 10px;
    width: 100%;
    position: relative;
    display: flex;
  }
  section.table .table-container {
    position: relative;
  }
  section.table .table-container .table-head {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    height: 100%;
    transition: transform 0.1s;
    will-change: transform;
  }
  section.table .table-container .table-head .table-box {
    color: white;
    background-color: #0C3387;
    text-align: center;
    font-feature-settings: "palt" on;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 100px;
    height: 100px;
    padding: 0;
    position: relative;
  }
  section.table .table-container .table-head .table-box span {
    position: absolute;
    left: -1px;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: calc(100% + 2px);
    height: 60px;
    background-color: #182D62;
    padding: 0 30px;
    white-space: nowrap;
  }
  section.table .table-container .table-body {
    padding-top: 100px;
  }
  section.table .table-container .table-body .table-box {
    border-right: 1px solid #CED6E7;
    border-bottom: 1px solid #CED6E7;
    text-align: center;
    font-feature-settings: "palt" on;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    min-width: 100px;
    height: 80px;
  }
  section.table .table-container .table-body .table-box a::after {
    content: "\ea09";
    display: inline-block;
    font-family: "icons";
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 12px;
    color: #0C3387;
  }
  section.table .table-container-fixed {
    margin-left: 7.6923076923vw;
    width: clamp(100px, 46.1538461538vw, 185px);
    min-width: clamp(100px, 46.1538461538vw, 185px);
    height: 100%;
    overflow: hidden;
  }
  section.table .table-container-fixed .table-body {
    border-left: 1px solid #CED6E7;
  }
  section.table .table-container-fixed .table-body .table-box span {
    word-wrap: break-word;
    width: 100%;
  }
  section.table .table-container-scroll {
    cursor: ew-resize;
  }
  section.table .table-container-scroll .swiper-slide.table-slide {
    min-width: 150px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide .table-head::before {
    content: "";
    width: calc(100% + 2px);
    height: 100px;
    background-color: #0C3387;
    position: absolute;
    top: 0;
    left: -1px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-of-type(2) .table-head .table-box::after {
    content: "製品";
    position: absolute;
    top: 10px;
    left: 1em;
    width: 100%;
    text-align: left;
    white-space: nowrap;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-of-type(5) .table-head .table-box::after {
    content: "Windows10正式版の互換性情報";
    position: absolute;
    top: 10px;
    right: 8em;
    width: 100%;
    text-align: right;
    white-space: nowrap;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(1) {
    width: 150px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(2) {
    width: clamp(150px, 46.1538461538vw, 220px);
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(2) .table-box {
    font-size: 11px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(3), section.table .table-container-scroll .swiper-slide.table-slide:nth-child(4) {
    width: 100px;
    min-width: 100px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(5) {
    width: clamp(150px, 38.4615384615vw, 200px);
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(odd) {
    background-color: #F2F6FD;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:last-child {
    margin-right: 7.6923076923vw;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media screen and (min-width:768px) {
  .table-title {
    padding-top: 20px;
    leading-trim: both;
    text-edge: cap;
    font-feature-settings: "palt" on;
    font-size: 18px;
    font-weight: 700;
    line-height: 1em;
    letter-spacing: 0.05em;
  }
  section.table {
    margin-top: 20px;
    position: relative;
    display: flex;
  }
  section.table .table-container {
    position: relative;
  }
  section.table .table-container .table-head {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    height: 100%;
  }
  section.table .table-container .table-head .table-box {
    color: white;
    background-color: #0C3387;
    text-align: center;
    font-feature-settings: "palt" on;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100px;
    padding: 0;
    position: relative;
  }
  section.table .table-container .table-head .table-box span {
    position: absolute;
    left: -1px;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: calc(100% + 2px);
    height: 60px;
    background-color: #182D62;
    padding: 0 30px;
    white-space: nowrap;
  }
  section.table .table-container .table-body {
    padding-top: 100px;
  }
  section.table .table-container .table-body .table-box {
    border-right: 1px solid #CED6E7;
    border-bottom: 1px solid #CED6E7;
    text-align: center;
    font-feature-settings: "palt" on;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.4em;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    height: 65px;
  }
  section.table .table-container .table-body .table-box a::after {
    content: "\ea09";
    display: inline-block;
    font-family: "icons";
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 12px;
    color: #0C3387;
  }
  section.table .table-container .table-body .table-box a:hover {
    text-decoration: underline;
  }
  section.table .table-container-fixed {
    width: 220px;
    min-width: 220px;
    height: 100%;
    overflow: hidden;
  }
  section.table .table-container-fixed .table-body {
    width: 100%;
    border-left: 1px solid #CED6E7;
  }
  section.table .table-container-fixed .table-body .table-box {
    width: 100%;
  }
  section.table .table-container-scroll {
    width: 100%;
  }
  section.table .table-container-scroll .table-head::before {
    content: "";
    width: calc(100% + 2px);
    height: 100px;
    background-color: #0C3387;
    position: absolute;
    top: 0;
    left: -1px;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-of-type(2) .table-head .table-box::after {
    content: "製品";
    position: absolute;
    top: 10px;
    left: 1em;
    width: 100%;
    text-align: left;
    white-space: nowrap;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-of-type(5) .table-head .table-box::after {
    content: "Windows10正式版の互換性情報";
    position: absolute;
    top: 10px;
    right: 8em;
    width: 100%;
    text-align: right;
    white-space: nowrap;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(1) {
    width: 20%;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(2) {
    width: 40%;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(3) {
    width: 10%;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(4) {
    width: 10%;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(5) {
    width: 20%;
  }
  section.table .table-container-scroll .swiper-slide.table-slide:nth-child(odd) {
    background-color: #F2F6FD;
  }
}