@charset "utf-8";

/* ------------------------------
            共通
------------------------------ */

body {
    margin: 0;
}

.entry * {
    margin: 0;
    padding: 0;
    font-family: "Noto Sans JP", sans-serif;
    color: #252525;
    text-align: center;
    font-feature-settings: "palt" 1;
}

.entry ul {
    list-style-type: none;
}

.entry h1,
.entry h2,
.entry h3 {
    font-weight: normal;
}

.entry img {
    max-width: 100%;
}

.sp {
    display: block;
}

.entry h3 {
    font-weight: bold;
    background-color: #f8f9fa;
    border-bottom: 3px #f5ba38 solid;
    padding: 20px 0;
    font-size: clamp(16px, 4vw, 22px);
    margin-bottom: 7%;
}

.entry section {
    padding-bottom: 13%;
}

.wrap_1,
.wrap_2 {
    width: 100%;
}

.wrap_2 {
    background-color: #fff;
    padding: 0 5%;
    box-sizing: border-box;
}

/* ------------------------------
            ロゴ
------------------------------ */

.main_img {
    background: url(/event/cyclekitchen/lib/2025/images/logo_bg_sp.jpg) no-repeat center center / cover;
    padding: 8% 5%;
}

.main_img h1 {
    width: 85%;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.2));
}

/* ------------------------------
            日付
------------------------------ */

.wrap_2 h2 {
    padding-top: 5%;
    margin-bottom: 5%;
}

/* ------------------------------
            これまでの様子
------------------------------ */

.past_photo {
	margin-bottom: 0;
    display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
    row-gap: .2em;
}

.past_photo a {
    flex: 0 0 49%;
    filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, 0.1));
}
.past_photo a:first-child {
    flex: 0 0 100%;
}

.pswp__counter {
    font-family: "MS Pゴシック",sans-serif;
}


/* ------------------------------
            出店案内
------------------------------ */

.guide {
    font-size: clamp(14px, 2vw, 18px);
}

.guide ul li:last-of-type {
    margin: 10px 0 20px 0;
}

.guide ul li span {
    font-weight: bold;
}

.guide dl  {
    width: 80%;
    margin: 0 auto;
}

.guide dl dt,
.guide dl dd {
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.1);
}

.guide dl dt {
    border: 2px #f5ba38 solid;
    border-radius: 10px;
    box-sizing: border-box;
    max-width: 400px;
    margin: 0 auto;
}

.guide dl dd {
    background-color: #f5ba38;
    border-radius: 10px;
    max-width: 400px;
    margin: 20px auto 30px auto;
}

.guide dl a {
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15px 10px;
}

.guide dl dt a img {
    width: 80%;
}

.guide dl dd a img {
    width: 45%;
}

.guide p {
    border: 1px solid #252525;
    padding: 10px;
    width: 85%;
    margin: 0 auto;
    font-size: clamp(16px, 3vw, 18px);
    line-height: 1.5em;
}

.guide p span {
    font-size: clamp(20px, 4vw, 22px);
    font-weight: bold;
}

.guide em {
    font-size: clamp(12px, 3vw, 16px);
    font-style: normal;
    margin-top: 10px;
    display: block;
}

/* ------------------------------
            お問い合せ
------------------------------ */

.contact dl dt {
    margin-bottom: 10px;
}

.contact dl dt span {
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 5px;
}

.contact dl dd small {
    font-size: clamp(10px, 3vw, 16px);
    font-weight: normal;
}

.contact dl dd {
    font-weight: bold;
    font-size: clamp(14px, 6vw, 16px);
    line-height: 1.8em;
}

.contact dl dd a {
    text-decoration: none;
    font-size: clamp(14px, 6vw, 16px)
}

/* ------------------------------
            開催概要
------------------------------ */

.overview {
    font-size: clamp(14px, 2vw, 18px);
}

.overview table {
    width: 90%;
    margin: 0 auto;
}

.overview table th,
.overview table td {
    display: block;
    width: 100%;
}

.overview table th {
    background-color: #e5e5e5;
    padding: 10px 0;
}

.overview table td {
    padding: 5% 0 7% 0;
}

.overview table tr:last-of-type td {
    padding-bottom: 0;
}

/* ------------------------------
            SNS
------------------------------ */

.sns ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    max-width: 500px;
    margin: 0 auto;
}

.sns ul li {
    width: 47%;
}

/* ------------------------------
            PC
------------------------------ */

@media screen and (min-width: 768px) {

    /* ------------------------------
            共通
    ------------------------------ */

    .sp {
        display: none;
    }    

    .entry {
        background-image: url('/event/cyclekitchen/lib/2025/images/bg.jpg');
        background-attachment: fixed;
        background-size: cover;
        background-position: center;
    }

    .wrap_1 {
        max-width: 1200px;
        margin: 0 auto;
    }

    .wrap_2 {
        width: 100%;
        padding: 0 5%;
    }

    .entry h3 {
        padding: 4% 0;
        margin-bottom: clamp(40px, 5vw, 60px);
        font-size: clamp(24px, 4vw, 30px);
    }

    .entry section {
        padding-bottom: clamp(70px, 6vw, 100px);
    }

    /* ------------------------------
            ロゴ・日付
    ------------------------------ */

    .main_img {
        background: url(/event/cyclekitchen/lib/2025/images/logo_bg_pc.jpg) no-repeat center center / cover;
    }

    /* ------------------------------
                これまでの様子
    ------------------------------ */

    .past_photo {
        row-gap: 0.5em;
    }

    .past_photo a,
    .past_photo a:first-child {
        flex: 0 0 32.333%;
        transition-duration: .3s;
    }

    .past_photo a:hover {
        opacity: .7;
    }

    /* ------------------------------
                出店案内
    ------------------------------ */

    .guide,
    .contact {
        font-size: clamp(16px, 2vw, 22px);
    }

    .guide ul li:last-of-type {
        margin: 20px 0 40px 0;
    }

    .guide dl dt,
    .guide dl dd  {
        box-shadow: 3px 3px 3px 0px rgba(0, 0, 0, 0.13);
        max-width: 500px;
        border-radius: 15px;
        transition-duration: .3s;
    }

    .guide dl dd {
        margin: 40px auto 60px auto;
    }

    .guide dl dt:hover,
    .guide dl dd:hover {
        opacity: .7;
    }

    .guide dl a {
        padding: 20px 10px;
    }

    .guide dl dt a img {
        width: 70%;
    }
    
    .guide dl dd a img {
        width: 40%;
    }

    .guide p {
        max-width: 900px;
        margin: 0 auto;
        padding: 20px;
        font-size: clamp(16px, 3vw, 22px);
    }

    .guide p span {
        font-size: clamp(14px, 4vw, 28px);
    }

    .guide em {
        font-size: clamp(14px, 3vw, 18px);
        margin-top: 20px;
    }

    /* ------------------------------
                お問い合せ
    ------------------------------ */

    .contact dl dt {
        margin-bottom: 20px;
    }

    .contact dl dd {
        font-size: clamp(14px, 3vw, 26px)
    }

    .contact dl dd a {
        color: #252525;
        font-size: clamp(14px, 3vw, 26px)
    }

    .contact dl dd a:first-of-type {
        pointer-events: none;
    }

    .contact dl dd a {
        transition-duration: .2s;
    }
    
    .contact dl dd a:last-of-type:hover {
        opacity: .6;
    }

    .contact dl dd small {
        font-size: clamp(14px, 2vw, 16px);
    }

    /* ------------------------------
                開催概要
    ------------------------------ */

    .overview {
        font-size: clamp(14px, 2vw, 20px);
        padding-bottom: 70px;
    }

    .overview table {
        max-width: 900px;
        margin: 20px auto;
        border-collapse: collapse;
    }

    .overview table tbody {
        border: 2px solid #252525;
    }

    .overview table tr {
        box-sizing: border-box;
    }

    .overview table th,
    .overview table td {
        box-sizing: border-box;
        padding: 20px;
        border: solid 1px #252525;
        display: table-cell;
    }

    .overview table th {
        width: 30%;
        background-color: #fff;
    }

    .overview table td {
        width: 70%;
        text-align: left;
        padding-left: 2em;
        display: table-cell;
    }

    .overview table tr:last-of-type td {
        padding-bottom: 20px;
    }

    /* ------------------------------
                SNS
    ------------------------------ */

    .sns ul {
        max-width: 700px;
    }

    .sns ul li a {
        transition-duration: .3s;
    }

    .sns ul li a:hover {
        opacity: .7;
    }





}