@charset "UTF-8";

body {
    font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
    color: #333;
    margin: 0;
    padding: 0;
}
/*-------ロゴ-------*/
#rogo {
    max-width: 1500px;
    margin: 0 auto;
}
#rogo img {
    width: 150px;
    margin-left: 120px;
    object-fit: cover;
}

/*-------メインヴィジュアル-------*/
.main-visual{
    background-color: #0cc0df;
    width: 1250px;
    height: 270px;
    border-radius: 30px;
    margin: 50px auto 100px;
    position: relative;
}
.main-visual img {
    position: absolute;
    border-radius: 50%;
    height: 270px;
    margin-left: 70px;
}
.main-visual .ball {
    position: absolute;
    background-color: #38b6ff;
    border-radius: 50%;
    height: 270px;
    width: 270px;
    margin-left: 900px;
}
.main-visual .main-visual-header {
    top: -10px;
    right: 0;
    bottom: 0;
    left: 0;
    position: absolute;
    text-align: center;
    font-size: 4rem;
    color: #fefffe;
    margin: 100px auto;
}

/*-------ヘッダー-------*/
.header {
    background-color: #0cc0df;
    width: 1200px;
    height: 150px;
    border-radius: 50px;
    margin: 50px auto 70px;
    color: #fefffe;
    position: relative;
}
.header2 {
    background-color: #ff8cab;
    width: 1200px;
    height: 150px;
    border-radius: 50px;
    margin: 50px auto 70px;
    color: #fefffe;
    position: relative;
}
.header3 {
    background-color: #0cc0df;
    width: 1200px;
    height: 150px;
    border-radius: 50px;
    margin: 50px auto 70px;
    color: #fefffe;
    position: relative;
}
.header-article {
    position: absolute;
    top: 0px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 1200px;
    height: 150px;
    text-align: center;
    line-height: 0.7;
    
}
.h2-page1 {
    font-size: 3rem;
    padding-top: 10px;
}
.h2-p-page1 {
    font-size: 1.3rem;
    text-align: right;
    padding-right: 70px;
}
.h2-p-page2 {
    font-size: 1.5rem;
    text-align: right;
    padding-right: 170px;
}
.h2-page3 {
    font-size: 3rem;
    padding-top: 10px;
    letter-spacing: 17px;
}
.h2-p-page3 {
    font-size: 1.5rem;
    text-align: left;
    padding-left: 180px;
}
.h2-page5 {
    font-size: 3rem;
    padding-top: 10px;
}
.h2-p-page5 {
    font-size: 1.5rem;
    text-align: right;
    padding-right: 150px;
}
.h2-page6 {
    font-size: 3.2rem;
    padding-top: 13px;
}

/*-------記事-------*/
.article {
    width: 1450px;
    margin: 0 auto 80px;
}
.article .article-h2-1 {
    font-size: 2.4rem;
    margin-left: 160px;
}
.h2-1-ex {
    width: 1300px;
    margin: 0 auto 80px;
}
.article-h2-1-ex {
    font-size: 1.8rem;
    margin-left: 90px;
    letter-spacing: 0.0005em;
}
.article p {
    font-size: 1.8rem;
    margin-left: 170px;
}
.article-p {
    width: 1400px;
}
.article-img {
    width: 1000px;
    margin: 0 auto 80px 25%;
}
.article-img img {
    width: 700px;
    margin-top: 50px;
    object-fit: cover;
    border-radius: 30px;
}
.article .article-h2-2 {
    font-size: 2.4rem;
    margin-left: 150px;
}
.article-img2 {
    width: 1000px;
    margin: 0 auto 70px;
}
.article-img2 img {
    margin-top: 30px;
    width: 1000px;
    object-fit: cover;
}

.article-img4 {
    width: 1000px;
    margin: 0 auto;
}
.article-img4 img {
    width: 1000px;
    object-fit: cover;
}
.article-img5 {
    width: 1200px;
    margin: 80px auto;
}
.article-img5 img {
    margin-left: 20%;
}
.article-list {
    width: 1450px;
    display: flex;
}
.article-list p {
    font-size: 1.8rem;
}
.article-list-div {
    flex-direction: column;
}
.article-list-div .article-list-p {
    width: 450px;
    border-bottom: 3px solid #000;
}
.article-list-size span {
    font-size: 1.4rem;
}

/*-------プロフィール-------*/
.profile {
    width: 1100px;
    margin: 0 auto 50px;
}
.profile .profile-style {
    width: 250px;
    object-fit: cover;
}
.profile-article {
    margin-left: 50px;
}
.profile p {
    font-size: 1.8rem;
}
.profile-img {
    width: 500px;
    margin: 0 auto;
}
.profile-img img {
    width: 280px;
    margin: 30px 0 0 140px;
    border-radius: 50%;
}
.profile .profile-style2 {
    width: 250px;
    object-fit: cover;
}
.profile-1 {
    width: 1100px;
    height: 80px;
    border-bottom: 5px solid #0cc0df;
    line-height: 3.3;
}
.profile-1 p {
    font-size: 2rem;
}
.profile-2 {
    width: 1100px;
    height: 300px;
    border-bottom: 5px solid #0cc0df;
    line-height: 2.5;
    display: flex;
}
.profile h3 {
    font-size: 2rem;
    font-weight: normal;
    line-height: 1;
}
.profile-2 p {
    margin-left: 170px;
    font-size: 1.5rem;
}
.profile-3 {
    width: 1100px;
    height: 200px;
    border-bottom: 5px solid #0cc0df;
    line-height: 1.7;
    display: flex;
}
.profile-3 p {
    margin-left: 170px;
    font-size: 1.8rem;
}
.profile-4 {
    width: 1100px;
    height: 350px;
    border-bottom: 5px solid #0cc0df;
    line-height: 1;
    display: flex;
}
.profile-4 li {
    margin: 20px 0 0 100px;
    font-size: 1.5rem;
}

/*-------フッター-------*/
/*-------ダウンロード-------*/
.download {
    display: flex;
    width: 700px;
    margin: 30px auto;
    justify-content: center;
}
.download img {
    width: 50px;
}
.dawnload-div {
    margin-left: 15px;
}
.download-p {
    font-size: 1.4rem;

}
.download-p:hover {
    color: #38b6ff;
}

/*-------フォーム-------*/
.form-container {
    background-color: #fff;
    padding: 30px 40px;
    border-radius: 8px;
    width: 1300px;
    margin: 0 auto;
}
.form-group {
    margin: 30px auto 20px;
}
label {
    display: block;
    margin-bottom: 8px;
    color: #555;
    font-weight: bold;
}
.required {
    background-color: #d9534f;
    color: #fefefe;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 8px;
}
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box; 
    font-size: 16px;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus {
    border-color: #007bff;
    outline: none;
    box-shadow: 0 0 5px rgba(0, 123, 255, 0.25);
}
.name-fields {
    display: flex;
    gap: 15px;
}
.name-fields input {
    width: 50%;
}
.radio-group label {
    font-weight: normal;
    display: inline-flex;
    align-items: center;
    margin-right: 20px;
}
.radio-group input[type="radio"] {
    margin-right: 8px;
}
button[type="submit"] {
    width: 500px;
    height: 50px;
    margin: 50px 0 0 400px;
    padding: 12px;
    background-color: #0cc0df;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 18px;
    font-weight: bold;
    transition: background-color 0.3s;
}
button[type="submit"]:hover {
    background-color: #38b6ff;
}

@media print {
    .print-none {
        display: none;
    }
}

/*スマートフォン用のスタイル (768px以下)*/

/*------- スマートフォン用のスタイル (780px以下) -------*/
@media (max-width: 780px) {

    /* 1. 基本設定 */
    body {
        font-size: 16px; /* スマホで見やすい基本サイズに */
        -webkit-text-size-adjust: 100%; /* iOSでの自動ズーム防止 */
    }

    /* 全ての主要コンテナの横幅をリセット */
    .main-visual,
    .header,
    .header2,
    .header3,
    .article,
    .profile,
    .form-container {
        width: auto; /* 固定幅を解除 */
        margin-left: 10px;
        margin-right: 10px;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box; /* paddingを含めて計算 */
    }

    /* 画像が画面からはみ出ないようにする */
    img {
        max-width: 100%;
        height: auto;
    }

    /* 2. ロゴ (index.html) */
    #rogo {
        text-align: center;
    }
    #rogo img {
        margin-left: 0; /* 中央寄せ */
    }

    /* 3. メインヴィジュアル (index.html) */
    .main-visual {
        height: auto; /* 高さを自動に */
        padding: 30px 15px;
        margin-top: 20px;
        margin-bottom: 40px;
    }
    .main-visual img,
    .main-visual .ball {
        display: none; /* 装飾的な要素を非表示にして簡略化 */
    }
    .main-visual .main-visual-header {
        position: static; /* 絶対配置を解除 */
        font-size: 1.1rem; 
        margin: 0;
        line-height: 1.4;
    }

    .download-p {
        font-size: 1.2rem ;
    } 

    /* 4. 各ページのヘッダー */
    .header, .header2, .header3 {
        height: auto;
        margin-bottom: 40px;
        padding: 10px 15px 20px;
        border-radius: 20px; /* 角丸を少し小さく */
    }
    .header-article {
        position: static;
        width: auto;
        height: 50px;
        line-height: 1.5; /* 行間を通常に */
    }
    .h2-page1, .h2-page3, .h2-page5, .h2-page6 {
        font-size: 1rem;
        padding-top: 0;
        letter-spacing: normal; /* .h2-page3 の字間をリセット */
    }
    .h2-p-page1, .h2-p-page2, .h2-p-page3, .h2-p-page5 {
        font-size: 0.7rem;
        text-align: center; /* サブタイトルを中央揃え */
        padding: 0;
        margin-top: 10px;
    }

    /* 5. 記事エリア (article) */
    .article {
        margin-bottom: 40px;
        padding: 0 10px; 
    }
    .article .article-h2-1,
    .article .article-h2-2 {
        font-size: 1.3rem;
        margin-left: 0; /* 左マージンを解除 */
        line-height: 1.5;
    }
    .article p {
        font-size: 1rem;
        margin-left: 0; /* 左マージンを解除 */
        line-height: 1.7;
    }
    .article-p {
        width: 100%; /* 固定幅を解除 */
    }
    .h2-1-ex {
        width: 350px;
        margin: 0 auto;
    }
    .article-h2-1-ex {
        margin-left: 0px;
        font-size: 1rem;
    }
    
    /* 記事エリアの画像 */
    .article-img,
    .article-img2,
    .article-img4 {
        width: 95%;
        margin: 0 auto;
    }
    .article-img5{
        width: 60%;
    }
    .article-img img,
    .article-img5 img {
        margin: 15px 0 0 0; /* マージンをリセット */
        border-radius: 15px; /* 角丸を少し */
    }
    .article-img2 img,
    .article-img4 img {
        width: 100%; /* グラフ画像なども全幅に */
        margin-top: 15px;
    }

    /* 記事リスト (index5.html) */
    .article-list {
        flex-direction: column; /* 縦積みに */
        width: 100%;
    }
    .article-list p {
        font-size: 1.1rem;
    }
    .article-list-div {
        margin-top: 10px;
    }
    .article-list-div .article-list-p {
        width: 100%; /* 全幅に */
    }
    .article-list-size span {
        font-size: 1rem;
        line-height: 1.7;
    }

    /* 6. プロフィール (index4.html) */
    .profile {
        margin-bottom: 30px;
    }
    .profile p {
        font-size: 0.9rem;
        line-height: 1.7;
    }
    .profile-article {
        margin-left: 0;
    }
    .profile-img {
        width: 100%;
        margin: 0;
    }
    .profile-img img {
        width: 200px; /* 画像サイズを調整 */
        height: 200px;
        margin: 20px auto; /* 中央寄せ */
        display: block;
    }
    /* 会社概要の各項目 */
    .profile-1,
    .profile-2,
    .profile-3,
    .profile-4 {
        width: 100%;
        height: auto; /* 高さを自動に */
        line-height: 1.5;
        padding: 10px 0;
        flex-direction: column; /* h3とp/ulを縦積み */
    }
    .profile-1 p{
        font-size: 0.8rem;
        font-weight: bold;
    }
    .profile h3 {
        font-size: 1.2rem;
        margin-bottom: 10px;
    }
    .profile-2 p,
    .profile-3 p {
        margin-left: 0; /* マージン解除 */
        font-size: 0.8rem;
        font-weight: bold;
    }
    .profile-4 ul {
         padding-left: 20px; /* リストの字下げ */
    }
    .profile-4 li {
        margin: 10px 0 0 0; /* マージン解除 */
        font-size: 0.8rem;
        font-weight: bold;
    }

    /* 7. フッター (ダウンロード & リンク) */
    .download {
        width: 100%;
        flex-direction: column; /* 縦積みに */
        align-items: center;
        text-align: center;
        margin-bottom: 30px;
    }
    .dawnload-div {
        margin-left: 0;
        margin-top: 10px;
    }
    .next-link {
        margin-top: 40px;
        margin-bottom: 40px;
        flex-wrap: wrap; /* ページリンクが多ければ折り返す */
    }

    /* 8. フォーム (index6.html) */
    .form-container {
        padding: 15px;
    }
    .form-group {
        margin-top: 25px;
    }
    .name-fields {
        flex-direction: column; /* 「姓」と「名」を縦積みに */
        gap: 0;
    }
    .name-fields input {
        width: 100%;
        margin-bottom: 15px;
    }
    /* 最後のマージンを削除 */
    .name-fields input:last-child {
        margin-bottom: 0;
    }
    .radio-group label {
        display: block; /* ラジオボタンを縦積みに */
        margin-bottom: 12px;
        margin-right: 0;
    }
    button[type="submit"] {
        width: 100%;
        margin: 30px 0 0 0; /* マージンをリセットして中央に */
        font-size: 1.1rem;
    }
}