@charset "utf-8";

/* 全体 */
html {}

:root {
    --max: 1200px;
    /* 中央カラムの最大幅 */
    --gutter: clamp(40px, 5vw, 0px);
    /* 左右の余白（可変） */
}

* {
    box-sizing: border-box;
}

html,
body {
    font-family: 'Yu Gothic', '遊ゴシック', 'ヒラギノ角ゴシック', 'MSゴシック', sans-serif;
    margin: 0;
}

.band {
    /* セクション自体は画面いっぱい */
    width: 100%;
}

.wrap {
    max-width: var(--max);
    margin-inline: auto;
    text-align: center;
    padding-inline: var(--gutter);
}

.wrap a {
    display: block;
    width: max-content;
    /* or fit-content */
    margin-inline: auto;
}

h1 {
    font-size: 32px;
    margin: 0;
}

h2 {
    font-size: 14px;
    margin: 0;
}

h3 {
    color: #2C3E50;
    font-size: 21px;
    margin: 0;
}

p {
    font-size: 16px;
    font-weight: bold;
    margin: 0;
}

ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    padding-inline-start: 0px;
}

li {
    font-weight: bold;
}


.br-pc {
    display: none;
}

img {
    max-width: 28%;
}

/* ///////////////////////共通部品/////////////////// */

/* ボタン */

.button {
    text-decoration: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    margin-inline: auto;
    padding: 1em 2.5em;
    border-radius: 10px;
    font-size: 1.1em;
    font-weight: bold;
    box-shadow: 0 2px 3px rgb(0 0 0 / 25%), 0 2px 3px -2px rgb(0 0 0 / 15%);
}

.button::after {
    transform: rotate(45deg);
    width: 5px;
    height: 5px;
    margin-left: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    content: '';
    display: inline-block;
}

/* 見出し */

.sub-title {
    margin-top: 100px;
    margin-bottom: 50px;
    position: relative;
    text-align: center;
}

.sub-title::before {
    background-color: #2C3E50;
    border-radius: 5px;
    bottom: -20px;
    content: "";
    height: 2px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    width: 60px;
}

/* 吹き出し */
.item-right {
    position: relative;
    display: inline-block;
    margin: 1.5em 15px 1.5em 0;
    padding: 30px 24px;
    min-width: 120px;
    max-width: 100%;
    color: #3C3C3C;
    font-size: 16px;
    background: #DED7C8;
    border-radius: 10px;
}

.item-right:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 100%;
    margin-top: -15px;
    border: 15px solid transparent;
    border-left: 15px solid #DED7C8;
}

.item-right p {
    margin: 0;
    padding: 0;
}

.item-left {
    position: relative;
    display: inline-block;
    margin: 1.5em 0 1.5em 15px;
    padding: 30px 24px;
    min-width: 120px;
    max-width: 100%;
    color: #3C3C3C;
    font-size: 16px;
    background: #DED7C8;
    border-radius: 10px;
}

.item-left:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -8.5%;
    margin-top: -15px;
    border: 15px solid transparent;
    border-right: 15px solid #DED7C8;
}

.item-left p {
    margin: 0;
    padding: 0;
}

/* ////////////////////////実際のページ////////////////////// */

/* ヘッダー */

header {
    height: 55px;
    padding: 0;
    text-align: left;
    background-color: #DED7C8;
}

.header-inner {
    min-width: 0;
    min-height: 0;
    overflow: hidden;
    max-width: var(--max-width);
    height: 60px;
    padding-left: 0;
    margin: -5px auto;
    display: flex;
    align-items: left;
    position: relative;
}


.header-inner img {
    object-fit: contain;
}

/* //////////////////ヒーローセクション //////////////////////// */

.band--hero {
    padding-top: 54px;
    padding-bottom: 60px;
    background-size: cover;
    background-position: center;
    background-image: url(img/KeyVisual.jpeg);
    background-color: rgba(90, 90, 90, 0.8);
    background-blend-mode: lighten;
}

.band--hero h1,
.band--hero h2,
.band--hero a {
    color: rgb(255, 255, 255);
    text-align: left;

}

.main-copy {
    margin: 0;

}

.sub-copy {
    margin-top: 17px;
}

.band--hero .button {
    margin-top: 30px;
    margin-left: 0;
    background-color: #0F121B;
    border: 2px solid #fff;
}

/* ////////////////////問いかけセクション///////////////////// */

.band--problem ul {
    padding-inline-start: 1px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.band--problem .item-right {
    width: 372px;
    margin-top: 0;
    margin-bottom: 40px;
    min-height: 40px;
    text-align: justify;
}

.band--problem .item-left {
    width: 372px;
    margin-top: 0;
    margin-bottom: 40px;
    min-height: 40px;
    text-align: justify;
}

.band--problem a {
    color: #ffffff;
    border: 2px solid #ffffff;
    justify-content: center;
    margin-top: 40px;
    background-color: #6C7B95;
}

.band--problem a::after {
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
}


/* ////////////////////munyセクション/////////////////// */

.img-muny {
    max-width: 100%;
    height: 260px;
    object-fit: cover;
    margin: 0 auto;

}

.band--muny p {
    text-align: justify;
    padding: 18px 0;

}

.band--muny a {
    color: #ffffff;
    border: 2px solid #ffffff;
    justify-content: center;
    margin-top: 40px;
    background-color: #C29F3A;
}

.band--muny a::after {
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
}

/* ////////////////////特徴セクション//////////////////// */

.diver {
    position: relative;
}

.custom-shape-divider-top-1755828804 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.custom-shape-divider-top-1755828804 svg {
    position: relative;
    display: block;
    width: calc(146% + 1.3px);
    height: 49px;
}

.custom-shape-divider-top-1755828804 .shape-fill {
    fill: #FAF7F2;
}

.band--point {
    background-color: #FAF7F2;
    padding-bottom: 65px;
}

.band--point .sub-title {
    padding-top: 43px;
    margin-bottom: 50px;
}

.band--point .sub-title::before {
    width: 0px;
}

.point-inner {
    padding: 10px;
    color: #3C3C3C;
    text-align: justify;
    margin-bottom: 70px;
}

.point-count {
    color: #C29F3A;
    font-size: 2em;
    padding-top: 0;
    margin: 0 auto 0;
    height: 40px;
    position: relative;
    text-align: center;
}

.point-count::before {
    background-color: #707070;
    bottom: -10px;
    width: 15px;

    border-radius: 5px;
    content: "";
    height: 2px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
}

.band--point ol {
    list-style: none;
    padding: 0;
}

.point-title {
    color: #3C3C3C;
    padding-top: 20px;
    margin-bottom: 0;
}

.band--point a {
    color: #2C3E50;
    border: 2px solid #2C3E50;
    justify-content: center;
    margin-top: 40px;
}

.band--point a::after {
    border-top: 2px solid #2C3E50;
    border-right: 2px solid #2C3E50;
}

.img-point {
    text-align: center;
    display: block;
    max-width: 60%;
    height: auto;
    margin: -20px auto;
    width: 230px;
    height: 220px;
}

.band--point a {
    color: #ffffff;
    border: 2px solid #ffffff;
    justify-content: center;
    margin-top: 40px;
    background-color: #0C215B;
}

.band--point a::after {
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
}

/* //////////////////作家の声セクション/////////////// */

.band--voice {
    background-color: #DED7C8;
    padding-bottom: 30px;
}

.band--voice .sub-title {
    color: #3C3C3C;
    padding-top: 80px;
    margin-top: 0;
    margin-bottom: 20px;
}

.band--voice .sub-title::before {
    width: 0px;
}

.band--voice .item-right {
    background: #ffffff;
    border-radius: 10px;
    padding-top: 17px;
    padding-bottom: 10px;

    width: 370px;
    margin-top: 0;
    margin-bottom: 40px;
    min-height: 40px;

}

.band--voice .item-right h2 {
    color: #3C3C3C;
    text-align: justify;
}


.band--voice .item-right:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 100%;
    margin-top: -15px;
    border: 15px solid transparent;
    border-left: 15px solid #ffffff;
}

.band--voice .item-left {
    background: #ffffff;
    border-radius: 10px;
    padding-top: 17px;
    padding-bottom: 10px;

    width: 370px;
    margin-top: 0;
    margin-bottom: 40px;
    min-height: 40px;

}

.band--voice .item-left h2 {
    color: #3C3C3C;
    text-align: justify;
}


.band--voice .item-left:before {
    content: "";
    position: absolute;
    top: 50%;
    left: -8.5%;
    margin-top: -15px;
    border: 15px solid transparent;
    border-right: 15px solid #ffffff;
}

.band--voice .item-who {
    display: block;          /* ←これが肝！ */
    margin-left: auto;       /* 自動で右に押し出す */
    margin-right: 0;
    width: max-content;      /* 中身の幅に合わせる */
    font-size: 14px;
}

.band--voice .introduction {
    color: #3C3C3C;
    text-align: center;
    margin-bottom: 60px;
}

/* //////////////////////締めセクション/////////////////// */

.band--finally {
    height: 360px;
    margin-bottom: 4em;
}

.band--finally h3 {
    font-size: 32px;
}

.band--finally h2 {
    color: #2C3E50;
    text-align: center;
    font-size: 16px;
}

.band--finally .sub-title {
    margin-bottom: 25px;
}

.band--finally .sub-title::before {
    width: 0px;
}

.band--finally a {
    color: #ffffff;
    border: 2px solid #ffffff;
    justify-content: center;
    margin-top: 40px;
    background-color: #E74C3C;
}

.band--finally a::after {
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
}

/* //////////////////////フッター/////////////////// */

footer {
    color: #fff;
    height: 2%;
}

footer p {
    background-color: #2C3E50;
    font-size: 9px;
    text-align: center;
}



/* //////////////////////フォーム/////////////////// */



.form_area {
    font-weight: 800;
    background-color: #FAF7F2;
    padding-bottom: 100px;
}

.form_area .sub-title {
    padding-top: 3em;
    margin-top: 3em;
}

.form_area .button {
    width: 100%;
    font-size: 1em;
    margin: 2em auto .5em;
    max-width: 300px;

    color: #ffffff;
    border: 2px solid #ffffff;
    justify-content: center;
    margin-top: 40px;
    background-color: #0C215B;
}

.form_area .wrap {
    text-align: left;
}

.Request {
    max-width: 600px;
    width: 100%;
    background-color: var(--white);
    border-radius: 30px;
    padding: 2rem;
    margin-left: 0;
}

.Request_link {
    display: inline !important;
}

.Request_label {
    color: #2C3E50;
    text-align: left;
}

.Must_Request {
    background-color: #E74C3C;
    color: #fff;
    font-size: 0.8em;
    padding: .2em;
    margin: auto .4em;
}

.Request_form {
    display: flex;
    flex-direction: column;
    gap: 1em;
    padding: 0 auto;
    width: 100%;
}

.Request_field {
    width: 100%;
    color: #2C3E50;
    border: 1px solid #6C7B95;
    border-radius: 5px;
    font-size: .9em;
    padding: .8em 4em .8em .5em;
    background-color: #fff;
}

.Request_privacy {
    white-space: nowrap;
}

.Request_errMsg {
    font-size: .8em;
    color: #E74C3C;
}

table {
    border-collapse: collapse;
}

input,
textarea {
    -webkit-user-select: auto;
}


textarea {
    white-space: revert;
}

label.Request_label {
    display: inline-flex;
    align-items: center;
    gap: .5em;
    line-height: 1.4;
}

label.Request_label>span.Must_Request {
    font-size: .7em;
    display: inline-block;
    padding: .1em .5em;
    height: 1.7em;
    line-height: 1.5em;
    background: #E74C3C;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}


.Request_field-ok {
    border-color: #198754;
    background-image: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512" fill="%23198754"><!--! Font Awesome Pro 6.2.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons, Inc. --><path d="M243.8 339.8C232.9 350.7 215.1 350.7 204.2 339.8L140.2 275.8C129.3 264.9 129.3 247.1 140.2 236.2C151.1 225.3 168.9 225.3 179.8 236.2L224 280.4L332.2 172.2C343.1 161.3 360.9 161.3 371.8 172.2C382.7 183.1 382.7 200.9 371.8 211.8L243.8 339.8zM512 256C512 397.4 397.4 512 256 512C114.6 512 0 397.4 0 256C0 114.6 114.6 0 256 0C397.4 0 512 114.6 512 256zM256 48C141.1 48 48 141.1 48 256C48 370.9 141.1 464 256 464C370.9 464 464 370.9 464 256C464 141.1 370.9 48 256 48z"/></svg>');
    background-repeat: no-repeat;
    background-size: 1.4em;
    background-position: top .6em right .7em;
}

.Request_field-errors {
    border-color: #E74C3C;
    background-image: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512" fill="%23dc3545"><!--! Font Awesome Pro 6.2.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license (Commercial License) Copyright 2022 Fonticons, Inc. --><path d="M256 512c141.4 0 256-114.6 256-256S397.4 0 256 0S0 114.6 0 256S114.6 512 256 512zm0-384c13.3 0 24 10.7 24 24V264c0 13.3-10.7 24-24 24s-24-10.7-24-24V152c0-13.3 10.7-24 24-24zm32 224c0 17.7-14.3 32-32 32s-32-14.3-32-32s14.3-32 32-32s32 14.3 32 32z"/></svg>');
    background-repeat: no-repeat;
    background-color: #fff2ef;
    background-size: 1.4em;
    background-position: top 0.6em right .7em;
}

.Request_privacy {
    text-align: center;
    font-size: 0.8rem;
}


.Request_field::placeholder {
    color: #c5c5c5;
    font-size: 0.9em;
}


/* //////////////送信しました//////////// */

.Request_commitMsg {
    text-align: center;
}

.Request_commitList {
    margin: 2em 0;
    padding: 2em;
    border-radius: 10px;
    text-align: left;
    background-color: #ffffff;
}

.Request_commitItem-ttl {
    margin-bottom: 0.2rem;
    padding: .2em  .5rem;
    border-bottom: 2px solid #DED7C8;
    color: #0F121B;
    font-size: .9em;
}
.Request_commitItem-txt {
    margin-left: 0em;
    padding-bottom: 1em;
}