.header {
    position: absolute;
    top: 20px;
    width: 100%;
    z-index: 999
}

@media screen and (min-width: 768px) {
    .header {
        position:fixed
    }
    .logo{

    }
}

.header__nav {
    align-items: center;
    display: flex;
    justify-content: space-between;
    position: relative;
    top: 0;
    width: 100%
}

@media screen and (min-width: 768px) {
    .header__nav {
        background-color:#fff;
        border-radius: 45px;
        box-shadow: 0 5px 25px #ffd7321a;
        padding: 1.25rem 3.125rem
    }
}
.works{
    display: none;
}
.price{
   display: none;
}
table{
    margin: 70px auto;
}
.header__title {
    font-family: Poppins,sans-serif;
    font-size: 1.5625rem;
    font-weight: 500;
    line-height: 1
}

@media screen and (max-width: 767px) {
    .header__title {
        left:23px;
        position: fixed;
        top: 42px;
        z-index: 1
    }

    .header__navLists {
        background-color: #fffae5;
        height: 100vh;
        left: 0;
        opacity: 0;
        padding-top: 10rem;
        position: fixed;
        top: 0;
        transition: .3s;
        visibility: hidden;
        width: 100%
    }
}
.logo{
    width: 61px;
    height: 50px;
}
@media screen and (min-width: 768px) {
    .header__navLists {
        align-items:center;
        -moz-column-gap: 1.875rem;
        column-gap: 1.875rem;
        display: flex
    }
}

@media screen and (max-width: 767px) {
    .header__navList {
        text-align:center
    }

    .header__navList+.header__navList {
        margin-top: 1.5625rem
    }
}

.header__navLink {
    color: #ffd732;
    display: inline-block;
    font-size: .9375rem;
    font-weight: 700;
    letter-spacing: .0375rem
}

@media screen and (min-width: 768px) {
    .header__navLink {
        letter-spacing:.04em
    }
}

.header__navLink--button {
    background-color: #ffd732;
    color: #fff
}

@media screen and (max-width: 767px) {
    .header__navLink--button {
        border-radius:25px;
        height: 3.125rem;
        line-height: 3.125rem;
        padding: 0 1.25rem;
        width: 17.1875rem
    }
}

@media screen and (min-width: 768px) {
    .header__navLink--button {
        border-radius:37px;
        font-size: .875rem;
        font-weight: 700;
        padding: .75rem 1.25rem
    }
}

.header__button {
    background-color: #ffd732;
    border-radius: 50%;
    display: block;
    height: 4.625rem;
    position: fixed;
    right: 20px;
    top: 20px;
    width: 4.625rem
}

@media screen and (min-width: 768px) {
    .header__button {
        display:none
    }
}

.header__buttonLine {
    background-color: #fff;
    border-radius: 3px;
    display: block;
    height: 3px;
    left: 0;
    margin-left: auto;
    margin-right: auto;
    position: absolute;
    right: 0;
    transition: .3s;
    width: 1.875rem
}

.header__buttonLine:first-of-type {
    top: 1.5625rem
}

.header__buttonLine:nth-of-type(2) {
    bottom: 0;
    margin-bottom: auto;
    margin-top: auto;
    top: 0
}

.header__buttonLine:nth-of-type(3) {
    bottom: 1.5625rem
}

.header__active .header__buttonLine {
    transition: .3s
}

.header__active .header__buttonLine:first-of-type {
    left: -.0625rem;
    top: 2.0625rem;
    transform: rotate(-45deg)
}

.header__active .header__buttonLine:nth-of-type(2) {
    display: none
}

.header__active .header__buttonLine:nth-of-type(3) {
    bottom: 2.3125rem;
    left: 0;
    transform: rotate(45deg)
}

@media screen and (max-width: 767px) {
    .header__active .header__navLists {
        opacity:1;
        transition: .3s;
        visibility: visible
    }
}

.footer {
    background: transparent linear-gradient(180deg,#ffd012,#e2d68e) 0 0 no-repeat padding-box;
    color: #fff
}

@media screen and (min-width: 768px) {
    .footer__wrap {
        display:grid;
        grid-template-columns: 1fr 23.125rem
    }
}

.footer__inner {
    padding: 3.75rem 3.125rem 3.125rem
}

@media screen and (min-width: 768px) {
    .footer__inner {
        padding:4.375rem 0 5rem 7.5rem
    }
}

.footer__logoLink {
    font-size: 2.5rem;
    font-weight: 700
}

.footer__nav {
    margin-top: 2.5rem
}

.footer__navInner {
    -moz-column-gap: .8125rem;
    column-gap: .8125rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(3,1fr);
    row-gap: 1.25rem
}

@media screen and (min-width: 768px) {
    .footer__navInner {
        -moz-column-gap:1.875rem;
        column-gap: 1.875rem;
        display: flex
    }
}
*,:after,:before {
    box-sizing: border-box
}

ol,ul {
    padding: 0
}

blockquote,body,dd,dl,figure,h1,h2,h3,h4,ol,p,ul {
    margin: 0
}

html {
    scroll-behavior: smooth
}

body {
    line-height: 1.5;
    min-height: 100vh;
    text-rendering: optimizeSpeed
}

ol,ul {
    list-style: none
}

a:not([class]) {
    -webkit-text-decoration-skip: ink;
    text-decoration-skip-ink: auto
}

img {
    display: block;
    max-width: 100%;
    width: 100%
}

img:not([alt]) {
    filter: blur(10px)
}

button,input,select,textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: transparent;
    border: none;
    border-radius: 0;
    font: inherit;
    outline: none
}

textarea {
    resize: vertical
}

input[type=checkbox],input[type=radio] {
    clip: rect(0,0,0,0);
    border: 0;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px
}

button,input[type=button],input[type=submit],label,select {
    cursor: pointer
}

select::-ms-expand {
    display: none
}

html {
    font-size: 16px
}

@media (max-width: 374px) {
    html {
        font-size:4.2780748663vw
    }
}

@media screen and (min-width: 768px) {
    html {
        font-size:1.3333333333vw
    }
}

@media (min-width: 1200px) {
    html {
        font-size:16px
    }
}

@media screen and (min-width: 768px) {
    a[href^="tel:"] {
        pointer-events:none
    }
}

a {
    color: inherit;
    text-decoration: none
}

body {
    background-color: #fff;
    color: #0b2b35;
    font-family: Noto Sans JP,sans-serif;
    font-weight: 400
}

.is-pc {
    display: none
}

@media screen and (min-width: 768px) {
    .is-pc {
        display:block
    }

    .is-sp {
        display: none
    }
}

.indent {
    display: inline-block
}

.inner {
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    width: 100%
}

@media screen and (min-width: 768px) {
    .inner {
        max-width:1250px;
        padding-left: 25px;
        padding-right: 25px
    }
}

@media screen and (max-width: 767px) {
    .sp-inner {
        margin-left:auto;
        margin-right: auto;
        padding-left: 20px;
        padding-right: 20px;
        width: 100%
    }
}

.wideInner {
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    width: 100%
}
.works {
    background-color: #fff;
    border-radius: 0 100px 0 0;
    margin-top: -4.375rem;
    padding-bottom: 10.9375rem;
    padding-top: 8.125rem
}

@media screen and (min-width: 768px) {
    .works {
        border-radius:0 200px 0 0;
        margin-top: -12.5rem;
        padding-bottom: 23.125rem;
        padding-top: 13.125rem
    }

    .works__inner {
        display: grid;
        grid-template-columns: max-content 1fr;
        grid-template-rows: auto auto
    }

    .works__titleContainer {
        grid-column: 1/2;
        grid-row: 1/2
    }
}
.works__cards {
    display: grid;
    margin-top: 4.0625rem;
    row-gap: 1.875rem
}

@media screen and (min-width: 768px) {
    .works__cards {
        -moz-column-gap:1.875rem;
        column-gap: 1.875rem;
        grid-column: 1/3;
        grid-row: 2/3;
        grid-template-columns: repeat(3,1fr);
        margin-top: 7.5rem
    }
}

.works__card {
    border-radius: 30px;
    box-shadow: 0 5px 25px #ffd7321a
}

.works__cardLink {
    display: block
}

.works__cardImage {
    aspect-ratio: 335/230;
    width: 100%
}

.works__cardImage img {
    border-radius: 30px 30px 0 0;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}
.section__title {
    font-size: 1rem;
    letter-spacing: .10625rem;
    line-height: 1;
    padding-left: 1.875rem;
    position: relative;
    z-index: 1
}

.section__title:before {
    background-color: #ffd732;
    content: "";
    display: block;
    height: 1.25rem;
    left: .3125rem;
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(30deg);
    width: 2px
}.blog__card {
    border-radius: 40px;
    box-shadow: 0 5px 25px #ffd7321a;
    overflow: hidden
}

.blog__cardLink {
    display: block
}

.blog__cardImage {
    aspect-ratio: 335/235;
    width: 100%
}

@media screen and (min-width: 768px) {
    .blog__cardImage {
        aspect-ratio:370/260
    }
}

.blog__cardImage img {
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain
}

.blog__cardContent {
    padding: 1.25rem 1.875rem 1.875rem
}

.blog__cardTitle {
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.2
}
.contact {
    background: transparent linear-gradient(180deg,#ebc118,#ffefab) 0 0 no-repeat padding-box;
    padding-bottom: 5.625rem;
    padding-top: 5.625rem;
    position: relative
}

@media screen and (min-width: 768px) {
    .contact {
        padding-bottom:6.25rem;
        padding-top: 10.625rem
    }
}

.contact__title {
    color: #ffd732;
    font-family: Montserrat,sans-serif;
    font-size: 4.0625rem;
    font-weight: 600;
    left: 0;
    letter-spacing: .1625rem;
    margin: 0 auto;
    position: absolute;
    right: 0;
    text-align: center;
    top: -3.125rem
}

@media screen and (min-width: 768px) {
    .contact__title {
        font-size:11.25rem;
        top: -8.75rem
    }
}

.contact__content {
    text-align: center
}

.contact__description {
    color: #fff;
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.36
}

@media screen and (min-width: 768px) {
    .contact__description {
        font-size:1.5rem
    }
}

.contact__note {
    color: #fff;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.187;
    margin-top: 1.25rem
}

@media screen and (min-width: 768px) {
    .contact__note {
        margin-top:1.5625rem
    }
}

.contact__buttonArea {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.875rem;
    max-width: 20.9375rem
}

.contact__button {
    align-items: center;
    background-color: #ffd732;
    border-radius: 40px;
    -moz-column-gap: .9375rem;
    column-gap: .9375rem;
    display: flex;
    justify-content: center;
    padding: 1.25rem 0
}

.contact__buttonIcon {
    background-image: url(../top/contact-icon.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    display: block;
    height: 1.1875rem;
    width: 1.5rem
}

.contact__buttonText {
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1
}

.blog__cardCategoryArea {
    margin-top: 1.5625rem
}

.blog__cardText {
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.75;
    margin-top: .9375rem
}

.section__title[data-ruby]:after {
    color: #ffeda1!important;
    content: attr(data-ruby);
    display: block;
    font-family: Montserrat,sans-serif;
    font-size: 4rem;
    font-weight: 600;
    left: 0;
    position: absolute;
    top: -4.6875rem
}

@media screen and (min-width: 768px) {
    .section__title[data-ruby]:after {
        font-size:11.25rem;
        left: 0;
        letter-spacing: .04em;
        text-indent: -.04em;
        top: -6.25rem;
        z-index: -1
    }
}

.works__cardTextArea {
    display: grid;
    padding: 1.25rem 1.875rem;
    row-gap: .625rem
}

.works__cardTitle {
    font-size: 1.25rem;
    font-weight: 500
}

.works__cardTextUrl {
    color: #ffd732;
    font-size: .75rem
}

.works__button {
    margin-top: 4.6875rem;
    text-align: right
}

@media screen and (min-width: 768px) {
    .works__button {
        grid-column:2/3;
        grid-row: 1/2;
        margin-top: 0
    }
}

@media screen and (min-width: 768px) {
    .wideInner {
        max-width:1490px;
        padding-left: 25px;
        padding-right: 25px
    }
}

.minInner {
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    width: 100%
}

@media screen and (min-width: 768px) {
    .minInner {
        max-width:870px;
        padding-left: 25px;
        padding-right: 25px
    }
}

.footer__navLink {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: .04rem
}

.footer__copy {
    background: transparent linear-gradient(359deg,#ebc118,#ffefab) 0 0 no-repeat padding-box;
    border-radius: 100px 0 0;
    padding-bottom: 3.125rem;
    padding-right: 3.125rem;
    padding-top: 3.125rem;
    text-align: right;
    width: 100%
}

@media screen and (min-width: 768px) {
    .footer__copy {
        border-radius:200px 0 0;
        padding-bottom: 5.0625rem;
        padding-right: 0;
        padding-top: 9.1875rem;
        text-align: center
    }
}

.footer__copy small {
    color: #fff;
    font-size: .75rem;
    font-weight: 400
}

.privacy {
  margin: 70px auto;
  max-width: 65.625rem;
}
.privacy span {
  font-weight: bold;
  font-size: 1.1rem;
}
.privacy h3 {
  font-size: 1.5rem;
}
.privacy-contact {
  text-align: right;
}
.privacy li{
    list-style: inside;
    text-indent: -1em;
    padding-left: 1em; 
  }

@media screen and (max-width: 768px) {
  .privacy {
    width: 85%;
  }
}

.imasuru {
    text-align: center;
    padding-top: 20px;
}

.imasuru-img {
    width: 80px;
    margin: 0 auto;
}

.imasuru p {
    padding-top: 50px;≥
}

