@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
*/

/* =========================================
   一覧グリッド
========================================= */
#list{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:20px;
}

/* =========================================
   施設カード（グリッド）
========================================= */
.facility-card{
    background:#fff;
    border-radius:10px;
    overflow:hidden;
    border:1px solid #eee;
    transition:0.3s;
}
.facility-card:hover{
    transform:translateY(-5px);
    box-shadow:0 10px 20px rgba(0,0,0,0.1);
}
.facility-card a{
    color:inherit;
    text-decoration:none;
}

.facility-image img{
    width:100%;
    height:180px;
    object-fit:cover;
}

.facility-body{
    padding:15px;
}
.facility-body h3{
    font-size:16px;
    margin-bottom:5px;
}
.area{
    font-size:13px;
    color:#777;
    margin-bottom:10px;
}
.btn{
    display:inline-block;
    padding:6px 12px;
    background:#333;
    color:#fff;
    border-radius:5px;
    font-size:12px;
}

/* =========================================
   詳細ページ
========================================= */
.facility-detail{
    max-width:800px;
    margin:auto;
}

.main-image img{
    width:100%;
    height:400px;
    object-fit:cover;
    border-radius:10px;
}

.thumbs{
    display:flex;
    gap:10px;
    margin-top:10px;
}
.thumbs img{
    width:100px;
    height:70px;
    object-fit:cover;
    cursor:pointer;
    border-radius:5px;
}

.info{
    margin-top:20px;
}

/* =========================================
   横型カード（検索結果）
========================================= */
.cards{
    display:block;
}

.card{
    display:flex;
    gap:15px;
    margin-bottom:20px;
    background:#fff;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 4px 12px rgba(0,0,0,0.08);
    transition:0.2s;
    text-decoration:none;
    color:#333;
}
.card:hover{
    transform:translateY(-3px);
    box-shadow:0 8px 20px rgba(0,0,0,0.15);
}

.card-image img{
    width:180px;
    height:130px;
    object-fit:cover;
}

.card-body{
    padding:10px;
    flex:1;
}

.card-title{
    font-size:16px;
    font-weight:bold;
    margin-bottom:5px;
}
.card-area{
    font-size:13px;
    color:#666;
}

/* =========================================
   星評価（半分対応）
========================================= */
.card-review{
    margin-top:6px;
}

.star-wrap{
    position:relative;
    display:inline-block;
    font-size:16px;
    line-height:1;
}
.star-base{
    color:#ddd;
}
.star-fill{
    color:#f5b301;
    position:absolute;
    top:0;
    left:0;
    white-space:nowrap;
    overflow:hidden;
}

.review-text{
    font-size:12px;
    color:#666;
}

/* =========================================
   画像アップローダー
========================================= */
.image-uploader{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}

.image-label{
    font-weight:bold;
    margin-bottom:5px;
}

.image-box{
    border:2px dashed #ccc;
    border-radius:12px;
    height:150px;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    position:relative;
    background:#fafafa;
    transition:0.2s;
}
.image-box:hover{
    border-color:#0073aa;
    background:#f0f8ff;
}

.upload-inner{
    text-align:center;
    color:#666;
}
.upload-icon{
    font-size:28px;
    margin-bottom:5px;
}
.upload-text{
    font-size:13px;
    font-weight:bold;
}
.upload-sub{
    font-size:11px;
    color:#999;
}

.preview{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}
.preview img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:12px;
}

.optional{
    font-size:12px;
    color:#999;
}

.image-uploader{
    display:grid;
    grid-template-columns: repeat(3,1fr);
    gap:24px;
    margin-top:10px;
}

/* =========================
   各ブロック
========================= */
.image-item{
    list-style:none;
}

/* タイトル */
.image-label{
    font-weight:bold;
    margin-bottom:6px;
    font-size:14px;
}

/* =========================
   アップロードボックス
========================= */
.image-box{
    border:2px dashed #d0d5dd;
    border-radius:12px;
    height:160px;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    position:relative;
    background:#f9fafb;
    transition:all .2s ease;
}

.image-box:hover{
    border-color:#3b82f6;
    background:#eff6ff;
}

/* 中身 */
.upload-inner{
    text-align:center;
    color:#6b7280;
}

.upload-icon{
    font-size:28px;
    margin-bottom:5px;
}

.upload-text{
    font-weight:600;
    margin-bottom:4px;
}

.upload-sub{
    font-size:12px;
}

/* =========================
   プレビュー
========================= */
.preview{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}

.preview img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:12px;
}

/* =========================
   下部
========================= */
.image-actions{
    margin-top:6px;
}

.optional{
    font-size:12px;
    color:#999;
}