/*
* - モニター案件一覧 (archive)
* - モニター応募履歴 (history)
*/
@media screen and (max-width:480px) {
    #monitorListContainer,
    #monitorDetailContainer {
        width: 100%;
        margin: 100px 0 50px 0;
    }
    .breadcrumb {
        width: 90%;
        margin: 20px 0 20px 20px;
    }
    .header-title {
        color: rgb(230, 61, 148);
        text-align: center;
        font-size: 24px;
    }
    .header-description {
        margin: 0 20px;
    }
    /* monitor-list, page-history */
    #monitor-area {
        margin: 0 auto;
        border: #000000;
    }
    #monitor-list {
        margin: 0 20px;
        text-align: left;
    }

    .product {
        display: flex;
        flex-direction: column;
        border: 1px solid #000;
        padding: 10px;
        margin: 20px 0px;
        position: relative;
        border-radius: 10px;
    }

    .product-detail {

    }
    .product-image-pc {
        display: none;
    }
    .product-image-sp {
        flex-grow: 1;
        width: 100%;
        max-height: 50%; /* 任意の高さに調整 */
        object-fit: cover; /* 画像のアスペクト比を維持しながら均等に表示 */
    }
    .product-content {
        width: 100%;
    }
    .new-badge {
        position: absolute;
        width: 100px;
        top: -18px;
        left: 5px;
        background-color: rgb(187, 0, 1);
        color: white;
        padding: 5px;
        border-radius: 20px;
        font-size: 24px;
        text-align: center;
    }
    .tag {
        width: 120px;
        background-color: rgb(230, 61, 148);
        color: white;
        margin: 10px 5px;
        padding: 5px 20px;
        border-radius: 20px;
        font-size: 14px;
        text-align: center;
    }

    #see-more-button-wrap {
        width: 90%;
        margin: 0 auto;
    }

    #monitor-see-more {
        width: 100%;
        text-align: center;
        color: #ffffff;
        background-color: rgb(230, 61, 148);
        border: none;
        border-radius: 20px;
        margin: 20px auto 40px;
        padding: 10px;
        text-decoration: none;
    }


    /* ページネーション */
    .pagination {
        margin-top: 20px;
        text-align: center;
    }

    .pagination .page-numbers {
        display: inline-block;
        padding: 5px 10px;
        margin: 0 2px;
        border: 1px solid #ddd;
        background-color: #f9f9f9;
        color: #333;
        text-decoration: none;
        border-radius: 3px;
        height: auto;
    }

    .pagination .page-numbers.current {
        background-color: rgb(230, 61, 148);
        color: #fff;
    }

    .pagination .page-numbers:hover {
        background-color: rgb(230, 61, 148);
        color: #fff;
    }
    /* 検索フォーム */
    #search-form {
        border: 1px solid #ccc;
        padding: 10px;
        margin: 0 20px;
        text-align: left;
        border-radius: 3px;
        margin-bottom: 20px;
    }

    #search-form label {
        display: block;
        margin-bottom: 5px;
    }

    #search-form input[type="text"],
    #search-form select {
        width: 100%;
        padding: 8px;
        margin-bottom: 10px;
        border: 1px solid #ccc;
        border-radius: 4px;
        box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    }

    #search-form button {
        padding: 10px 20px;
        background-color: rgb(230, 61, 148);
        color: #fff;
        border: none;
        border-radius: 4px;
        cursor: pointer;
        width: 100%;
    }

    #search-form button:hover {
        background-color: rgb(230, 61, 148);
    }
    #keyword-form {
        width: 100%;
    }
    .keyword-label {
        display: flex;
    }
    .input-search-field {
        width: 100%;
        padding: 10px;
        border: 1px solid #ccc;
        border-radius: 5px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        font-size: 16px;
    }

    .input-search-field::placeholder {
        color: #999;
    }

    input.checkbox {
        margin: 0 10px;
    }
    .input-container {
        display: flex;
    }
    .search-icon {
        background-color: #cccccc;
        text-align: center;
    }
    .search-button {
        margin: 10px 0;
    }
    .not-found {
        margin: 20px 0;
        padding: 40px 0;
        font-size: 18px;
        text-align: center;
        /*background-color: rgb(209, 231, 221);*/
        background-color: #cccccc;
        border-radius: 10px;
        width: 100%;
    }
    .not-found .not-found-message {
        padding: 0 1px;
    }
    #monitor-search-result {
        text-align: center;
    }

    /* カスタムチェックボックススタイル */
    .checkbox-container {
        display: flex;
        flex-wrap: wrap;
    }

    .checkbox-label {
        position: relative;
        padding-left: 35px;
        margin-right: 20px;
        margin-bottom: 10px;
        cursor: pointer;
        font-size: 18px;
        line-height: 30px;
    }

    .checkbox-label input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
    }

    .checkmark {
        position: absolute;
        top: 0;
        left: 0;
        height: 30px;
        width: 30px;
        background-color: #eee;
        border-radius: 2px;
    }

    .checkbox-label .checkmark:after {
        content: "";
        position: absolute;
        display: none;
    }

    .checkbox-label input:checked ~ .checkmark:after {
        display: block;
    }

    .checkbox-label .checkmark:after {
        left: 8px;
        top: 4px;
        width: 10px;
        height: 20px;
        border: solid #000;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
        border-radius: 2px;
    }
}

/* タブレット・PC */
@media screen and (min-width: 481px) and (min-width: 960px) {
    #monitorListContainer,
    #monitorDetailContainer {
        width: 90%;
        margin: 100px auto;
    }
    .breadcrumb {
        width: 90%;
        margin: 20px auto;
        text-align: left;
        font-size: 1.4rem;
    }
    .header-title {
        color: rgb(230, 61, 148);
        text-align: center;
        font-size: 24px;
    }
    .header-description {
        margin: 0 20px;
    }
    /* monitor-list, page-history */
    #monitor-area {
        width: 90%;
        border: #000000;
        margin: 0 auto;
        text-align: center;
    }
    #monitor-area h1 {
        text-align: center;
        font-size: 2.4rem;
    }
    #monitor-list {
        display: flex;
        text-align: left;
/*        flex-direction:row; */
        flex-wrap: wrap;
/*        column-gap: 10px; */
        justify-content: space-between;
        align-items: flex-start; /* 追加 */

    }
    /*
    .monitor-list::after{
        content:"";
        display: block;
        width:30%;
    }
     */

    .product {
        display: flex;
        flex-direction: column;
        border: 1px solid #000;
        padding: 20px;
        position: relative;
        border-radius: 10px;
        width: 30%;
        margin: 35px 0px;
        height: 700px;
    }
    /*
    .product::after {
        content: "";
        width: 30%;
        border: 1px dashed #F7931F;
        color: #F7931F;
        padding: 10px;
    }
     */

    .product-detail {

    }
    .product-detail-product-image {
        width: 50%;
        margin: 0 auto;
    }
    .product-detail-category-area {
        width: 90%;
        margin: 20px auto;
    }
    .product-image-sp {
        display: none;
    }
    .product-image-pc {
        flex-grow: 1;
        width: 50%;
        max-height: 40%; /* 任意の高さに調整 */
        object-fit: cover; /* 画像のアスペクト比を維持しながら均等に表示 */
        margin: 0 auto;
        height: 200px;
    }
    .product-content {
        width: 100%;
    }
    .product-content h2 {
        font-size: 1.6rem;
    }
    .product-content th {
        font-size: 1.4rem;
    }
    .product-content td {
        font-size: 1.4rem;
    }
    .new-badge {
        position: absolute;
        width: 100px;
        top: -18px;
        left: 5px;
        background-color: rgb(187, 0, 1);
        color: white;
        padding: 5px;
        border-radius: 20px;
        font-size: 24px;
        text-align: center;
    }
    .tag {
        width: 120px;
        background-color: rgb(230, 61, 148);
        color: white;
        margin: 10px auto;
        padding: 5px 20px;
        border-radius: 20px;
        font-size: 1.2rem;
        text-align: center;
    }

    #see-more-button-wrap {
        width: 50%;
        margin: 0 auto;
    }
    #monitor-see-more {
        width: 100%;
        text-align: center;
        font-size: 1.8rem;
        color: #ffffff;
        background-color: rgb(230, 61, 148);
        border: none;
        border-radius: 50px;
        margin: 40px auto 100px;
        padding: 10px;
        text-decoration: none;
    }

    /* ページネーション */
    .pagination {
        margin-top: 20px;
        text-align: center;
    }

    .pagination .page-numbers {
        display: inline-block;
        padding: 5px 10px;
        margin: 0 2px;
        border: 1px solid #ddd;
        background-color: #f9f9f9;
        color: #333;
        text-decoration: none;
        border-radius: 3px;
        height: auto;
    }

    .pagination .page-numbers.current {
        background-color: rgb(230, 61, 148);
        color: #fff;
    }

    .pagination .page-numbers:hover {
        background-color: rgb(230, 61, 148);
        color: #fff;
    }
    /* 検索フォーム */
    #search-form {
        border: 1px solid #ccc;
        padding: 10px;
        margin: 0 20px;
        text-align: left;
        border-radius: 3px;
        margin-bottom: 20px;
        font-size: 1.4rem;
    }

    #search-form label {
        display: block;
        margin-bottom: 5px;
    }

    #search-form input[type="text"],
    #search-form select {
        width: 100%;
        padding: 8px;
        margin-bottom: 10px;
        border: 1px solid #ccc;
        border-radius: 4px;
        box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    }

    #search-form button {
        padding: 10px 20px;
        background-color: rgb(230, 61, 148);
        color: #fff;
        border: none;
        border-radius: 4px;
        cursor: pointer;
        width: 100%;
    }

    #search-form button:hover {
        background-color: rgb(230, 61, 148);
    }
    #keyword-form {
        width: 100%;
    }
    .keyword-label {
        display: flex;
    }
    .input-search-field {
        width: 100%;
        padding: 10px;
        border: 1px solid #ccc;
        border-radius: 5px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        font-size: 16px;
    }

    .input-search-field::placeholder {
        color: #999;
    }

    input.checkbox {
        margin: 0 10px;
    }
    .input-container {
        display: flex;
    }
    .search-icon {
        background-color: #cccccc;
        text-align: center;
    }
    .search-button {
        margin: 10px 0;
    }
    .not-found {
        margin: 20px 0;
        padding: 40px 0;
        font-size: 18px;
        text-align: center;
        /*background-color: rgb(209, 231, 221);*/
        background-color: #cccccc;
        border-radius: 10px;
        width: 100%;
    }
    .not-found .not-found-message {
        padding: 0 1px;
    }

    /* カスタムチェックボックススタイル */
    .checkbox-container {
        display: flex;
        flex-wrap: wrap;
    }

    .checkbox-label {
        position: relative;
        padding-left: 35px;
        margin-right: 20px;
        margin-bottom: 10px;
        cursor: pointer;
        font-size: 18px;
        line-height: 30px;
    }

    .checkbox-label input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
    }

    .checkmark {
        position: absolute;
        top: 0;
        left: 0;
        height: 30px;
        width: 30px;
        background-color: #eee;
        border-radius: 2px;
    }

    .checkbox-label .checkmark:after {
        content: "";
        position: absolute;
        display: none;
    }

    .checkbox-label input:checked ~ .checkmark:after {
        display: block;
    }

    .checkbox-label .checkmark:after {
        left: 8px;
        top: 4px;
        width: 10px;
        height: 20px;
        border: solid #000;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
        border-radius: 2px;
    }

    #monitor-search-result {
        color: rgb(230, 61, 148);
        text-align: center;
        font-size: 1.8rem;
    }
    #monitor-search-condition-area {
        width: 50%;
        margin: 0 auto;
    }
}
