@charset "UTF-8";
/*
Theme Name: EN Theme
Description: 海の家 EN 専用テーマ
Version: 1.0
*/

:root {
    --en-orange: #f15a24;
    --en-blue: #00429d;
    --en-border-light: #fceae3;
    --en-red: #d30b0b;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    margin: 0; padding: 0 0 100px 0!important;
    color: #333; background-color: #fff;
    line-height: 1.5;
}




.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
img { max-width: 100%; height: auto; display: block; }

/* --- Header --- */
header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 20px; background: #fff; position: sticky; top: 0; z-index: 1000;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}
.header-logo img { height: 40px; }
.btn-call-top { 
    border: 1px solid #ddd; border-radius: 25px; padding: 5px 15px; 
    font-size: 14px; text-decoration: none; color: var(--en-orange); font-weight: bold;
}

/* --- Hero --- */
.hero {
    background: url('assets/img/hero.png') center center / cover no-repeat;
    padding: 80px 20px 120px; text-align: left; position: relative; color: #fff;
}
.hero-title { font-size: 56px; font-weight: 900; margin: 0; text-shadow: 0 2px 10px rgba(0,0,0,0.4); }
.hero-title span { color: var(--en-orange); }

/* GRAND OPEN Card */
.go-card {
    background: #fff; border-radius: 20px; margin: -80px auto 40px;
    width: 95%; max-width: 900px; display: flex; padding: 30px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.1); align-items: center; position: relative; z-index: 10;
}
.go-sun { flex: 0 0 80px; }
.go-main { flex: 1; text-align: center; border-right: 2px solid #eee; padding: 0 20px; }
.go-main .date { font-size: 38px; color: var(--en-orange); font-weight: 900; margin: 0; line-height: 1; }
.go-main .text { font-size: 42px; color: var(--en-orange); font-weight: 900; margin: 5px 0 0; letter-spacing: 2px; }
.go-side { flex: 0 0 220px; padding-left: 30px; color: var(--en-blue); }
.go-side h3 { font-size: 18px; margin: 0; display: flex; align-items: center; gap: 8px; }
.go-side .open-time { font-size: 24px; font-weight: 900; margin: 8px 0 0; }

/* Features Grid */
.features-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 40px;
}
.f-card {
    border: 1px solid var(--en-border-light); border-radius: 20px; overflow: hidden;
    background: #fff; position: relative; text-align: center;
}
.badge-new {
    position: absolute; top: 0; left: 0; background: var(--en-orange); color: #fff;
    padding: 4px 12px; font-weight: bold; border-bottom-right-radius: 15px; font-size: 12px;
}
.f-card-header { padding: 15px 10px 5px; font-size: 14px; font-weight: bold; color: #666; }
.f-card h4 { font-size: 24px; margin: 0 0 10px; font-weight: 900; }
.f-card-img { height: 180px; background-size: cover; background-position: center; }
.f-card-footer { padding: 15px; font-size: 14px; color: #444; background: linear-gradient(to bottom, #fff, #fff5f0); }

/* Icon Grid */
.icon-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 15px; margin-bottom: 50px;
}
.icon-box {
    background: #fff; border: 1px solid #f0f0f0; border-radius: 12px; padding: 15px 5px;
    text-align: center; font-size: 13px; font-weight: bold; color: var(--en-blue);
}
.icon-box img { width: 40px; margin: 0 auto 10px; }

/* --- Shower Area --- */
.shower-detail-container { background: #f4f9ff; padding: 20px 0; margin-top: 20px; }
.shower-frame { border: 2px solid #00429d; border-radius: 10px; background: #fff; position: relative; overflow: hidden; display: flex; flex-wrap: wrap; }
.shower-title-tab { background: #00429d; color: #fff; padding: 5px 25px; border-radius: 0 0 15px 0; font-weight: bold; font-size: 18px; }
.shower-content-left { flex: 1; padding: 20px; min-width: 300px; }
.price-orange-box { border: 2px solid #f15a24; border-radius: 10px; padding: 10px; text-align: center; margin: 15px 0; }
.price-orange-box .big-p { color: #f15a24; font-size: 36px; font-weight: 900; }
.amenity-icons { display: flex; gap: 10px; margin-top: 15px; }
.amenity-item { background: #f9f9f9; border-radius: 8px; padding: 5px; text-align: center; flex: 1; }
.amenity-item img { width: 30px; margin: 0 auto; }
.amenity-item span { font-size: 10px; display: block; line-height: 1.2; margin-top: 4px; }
.shower-content-center { width: 140px; padding: 20px 10px; text-align: center; border-left: 1px dashed #ccc; border-right: 1px dashed #ccc; }
.towel-badge { background: #ffcc00; width: 80px; height: 80px; border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; font-size: 11px; font-weight: bold; margin: 0 auto 10px; color: #d30b0b; }
.towel-badge b { font-size: 18px; }
.shower-content-right { flex: 1.5; padding: 15px; min-width: 350px; background: #fff; }
.usage-steps-box { background: #fdfdfd; border: 1px solid #eee; border-radius: 10px; padding: 10px; }
.steps-row { display: flex; justify-content: space-between; align-items: flex-start; margin-top: 10px; }
.step-unit { text-align: center; flex: 1; position: relative; }
.step-unit:not(:last-child)::after { content: "▶"; position: absolute; top: 40%; right: -10%; color: #00429d; font-size: 12px; }
.step-circle { background: #00429d; color: #fff; width: 22px; height: 22px; border-radius: 50%; margin: 0 auto 5px; font-size: 12px; display: flex; align-items: center; justify-content: center; }
.step-unit img { width: 50px; height: 50px; object-fit: contain; margin: 0 auto 5px; }
.step-unit p { font-size: 10px; font-weight: bold; line-height: 1.3; }
.red-warning-bar { background: #d30b0b; color: #fff; text-align: center; padding: 8px; font-weight: bold; font-size: 13px; border-radius: 20px; margin-top: 15px; }

/* --- Udon Banner --- */
.udon-wide-banner-section {
    padding: 30px 0;
}

.udon-wide-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    border: 1.5px solid #fceae3;
    border-radius: 15px;
    background: #fffdf9;
    padding: 22px 36px;
}

.udon-info-text {
    flex: 1.2;
    text-align: left;
}

.udon-main-copy {
    font-size: 26px;
    font-weight: 900;
    margin: 6px 0;
    color: #333;
    line-height: 1.25;
}

.udon-main-copy span {
    color: #f15a24;
}

.udon-visual-group {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 24px;
    flex: 1.5;
}

.udon-bowl-unit {
    position: relative;
    width: 260px;
    flex-shrink: 0;
}

.udon-main-photo img {
    width: 100%;
    height: auto;
    display: block;
}

.udon-stamp-badge {
    position: absolute;
    top: 10px;
    left: -35px;
    width: 76px;
    height: 76px;
    border: 2px solid #d30b0b;
    border-radius: 50%;
    background: #fff;
    color: #d30b0b;
    font-weight: 900;
    font-size: 13px;
    line-height: 1.2;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    transform: rotate(-10deg);
    z-index: 5;
}

.udon-brand-logo {
    flex-shrink: 0;
}

.udon-brand-logo img {
    width: 170px;
    height: auto;
    display: block;
}

/* SP */
@media (max-width: 900px) {
    .udon-wide-banner {
        padding: 18px 16px;
        gap: 14px;
    }

    .udon-info-text {
        flex: 1;
    }

    .udon-main-copy {
        font-size: 18px;
    }

    .udon-info-text p {
        font-size: 12px;
    }

    .udon-visual-group {
        gap: 8px;
        flex: 1;
    }

    .udon-bowl-unit {
        width: 110px;
    }

    .udon-stamp-badge {
        width: 46px;
        height: 46px;
        font-size: 9px;
        top: 0;
        left: -18px;
    }

    .udon-brand-logo img {
        width: 82px;
    }
}

/* --- MENU --- */
.menu-head { text-align: center; margin: 60px 0 30px; position: relative; }
.menu-head h2 { color: var(--en-orange); font-size: 28px; font-weight: 900; display: inline-block; padding: 0 40px; background: #fff; position: relative; z-index: 2; }
.menu-head::after { content: ""; position: absolute; top: 50%; left: 0; width: 100%; height: 2px; background: var(--en-orange); z-index: 1; }

.menu-grid {
    display: grid;
    grid-template-columns: repeat(4, 1.1fr) 1.8fr;
    gap: 12px; margin-bottom: 50px;
}
.menu-box {
    border: 1.5px solid var(--en-border-light); border-radius: 15px; padding: 15px 8px;
    background: #fff; display: flex; flex-direction: column; min-width: 0;
}
.menu-box h5 {
    text-align: center; color: var(--en-blue); border-bottom: 2px solid var(--en-orange);
    margin: 0 0 15px; padding-bottom: 8px; font-size: 16px; font-weight: 900;
}
.m-row { display: flex; justify-content: space-between; align-items: center; font-size: 11px; margin-bottom: 8px; font-weight: bold; width: 100%; }
.m-row span:first-child { white-space: nowrap; overflow: hidden; margin-right: 4px; }
.m-row .price { color: #333; white-space: nowrap; flex-shrink: 0; }
.menu-box:last-child .m-row { font-size: 9.5px; }

/* --- Bottom Info --- */
.bottom-info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; margin: 40px 0; }
.info-card { border: 1px solid #ddd; border-radius: 15px; padding: 20px; background: #fff; display: flex; flex-direction: column; justify-content: space-between; }
.access-box { display: flex; align-items: flex-start; gap: 10px; }
.map-thumb { width: 120px; height: 120px; border-radius: 10px; background: #e0e0e0; }
.insta-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; margin: 10px 0; }
.insta-gallery div { aspect-ratio: 1; background: #eee; border-radius: 5px; }
.btn-insta-follow { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); color: #fff; text-align: center; padding: 10px; border-radius: 25px; text-decoration: none; font-weight: bold; font-size: 14px; position: relative; }
.btn-insta-follow::after { content: ">"; position: absolute; right: 15px; }
.contact-card { text-align: center; }
.contact-phone { color: #f15a24; font-size: 32px; font-weight: 900; margin: 5px 0; display: flex; align-items: center; justify-content: center; gap: 10px; }
.btn-reserve-orange { background: #f15a24; color: #fff; padding: 15px; border-radius: 15px; text-decoration: none; font-weight: 900; font-size: 20px; display: block; margin-top: 10px; box-shadow: 0 4px 0 #c0481d; }

/* --- Fixed Nav --- */
.sticky-nav { position: fixed; bottom: 0; width: 100%; display: grid; grid-template-columns: 1fr 1fr 1fr; z-index: 2000; }
.sticky-nav a { text-align: center; padding: 18px 5px; color: #fff; text-decoration: none; font-weight: bold; font-size: 15px; }
.sn-res { background: var(--en-orange); }
.sn-tel { background: #ff7e50; }
.sn-ins { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }

/* --- Responsive --- */
@media (max-width: 900px) {
    /* 共通設定 */
    .container { padding: 0 15px; }

    /* ① グランドオープンカードの修正 */
    .go-card {
        flex-direction: column;
        padding: 20px;
        margin: -50px auto 30px; /* 引き上げ幅を少し小さく調整 */
        width: 90%;
    }
    .go-sun {
        flex: 0 0 auto;
        width: 120px; /* 太陽が巨大化しないようサイズ制限 */
        margin: 0 auto 10px;
    }
    .go-main {
        border-right: none;
        border-bottom: 2px solid #eee;
        padding: 10px 0 20px;
        width: 100%;
    }
    .go-main .date {
        font-size: 24px; /* スマホ用にサイズダウン */
    }
    .go-main .text {
        font-size: 28px; /* スマホ用にサイズダウン */
        letter-spacing: 1px;
    }
    .go-side {
        flex: 0 0 auto;
        padding: 20px 0 0 0;
        width: 100%;
    }

    /* ② うどんバナー部分の修正 */
    .udon-wide-banner {
        flex-direction: column;
        text-align: center;
        padding: 30px 15px;
    }
    .udon-main-copy {
        font-size: 20px; /* 文字をスマホ幅に収める */
        line-height: 1.4;
    }
    .udon-stamp-badge {
        margin: 15px auto;
        position: static; /* 流れの中に配置 */
    }
    .udon-main-photo {
        width: 100%; /* 横幅いっぱい */
        max-width: 300px; /* 大きくなりすぎないよう制限 */
        height: auto; /* 高さを固定しない */
        margin: 15px auto;
        flex: 0 0 auto;
    }
    .udon-brand-logo {
        margin-top: 10px;
    }
    .udon-brand-logo img {
        width: 120px; /* ロゴのサイズ調整 */
        margin: 0 auto;
    }

    /* メニュー・その他 */
    .menu-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .features-grid { grid-template-columns: 1fr; }
    .bottom-info-grid { grid-template-columns: 1fr; }
    .hero-title { font-size: 32px; } /* ヒーローの文字もスマホ用に調整 */
}