/**
 * スタッフカード共通スタイル
 * 
 * このコンポーネントは以下の場所で使用されます：
 * - トップページ（今日の出勤）
 * - スタッフ一覧ページ
 * - スケジュールページ
 * - 予約ページ
 * 
 * 【重要】レイアウト仕様
 * - PC表示: 必ず4列表示
 * - タブレット表示: 3列表示
 * - SP表示: 必ず2列表示
 * - これらの列数は固定であり、画面幅に応じて自動的に列数が変わることはありません
 * - グリッドアイテムは自動的に伸縮してコンテナ幅に合わせます
 */

/* スタッフカード基本 */
.c-staffCard {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    min-width: 0; /* グリッドアイテムの最小幅をリセット */
}

.c-staffCard:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-4px);
}

/* 画像エリア */
.c-staffCard__image {
    display: block;
    position: relative;
    width: 100%;
    padding-top: 125%; /* 4:5のアスペクト比（より縦長） */
    overflow: hidden;
    background: #f0f0f0;
}

.c-staffCard__image img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 新人バッジ */
.c-staffCard__badge {
    position: absolute;
    bottom: 10px;
    right: 10px;
    z-index: 10;
}

.c-staffCard__badge--new {
    display: inline-block;
    background: linear-gradient(135deg, #ff4444, #ff6666);
    color: #fff;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(255, 68, 68, 0.3);
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
    100% {
        transform: scale(1);
    }
}

/* コンテンツエリア */
.c-staffCard__body {
    padding: 20px;
}

/* スタッフ名 */
.c-staffCard__name {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #303c09;
}

/* 出勤時間（オプション） */
.c-staffCard__shift {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 15px;
    font-size: 14px;
    color: #666;
}

.c-staffCard__shift i {
    color: #303c09;
}

/* メタ情報（2行2列グリッド） */
.c-staffCard__meta {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-bottom: 20px;
}

.c-staffCard__metaItem {
    display: flex;
    gap: 0.5em; /* 半角1文字分の余白 */
    align-items: center;
    font-size: 14px;
}

.c-staffCard__metaLabel {
    color: #666;
    font-size: 10px;
}

.c-staffCard__metaValue {
    font-weight: 700;
    color: #333;
}

/* アクションボタン */
.c-staffCard__button {
    display: block;
    width: 100%;
    padding: 12px;
    background: #303c09;
    color: #fff;
    text-align: center;
    text-decoration: none;
    border-radius: 4px;
    font-weight: 700;
    transition: all 0.3s ease;
}

.c-staffCard__button:hover {
    background: #1f2806;
}

/* レスポンシブ */
@media (max-width: 768px) {
    .c-staffCard__body {
        padding: 16px;
    }
    
    .c-staffCard__name {
        font-size: 18px;
        margin-bottom: 12px;
    }
    
    .c-staffCard__shift {
        font-size: 13px;
        margin-bottom: 12px;
    }
    
    .c-staffCard__meta {
        gap: 8px;
        margin-bottom: 16px;
    }
    
    .c-staffCard__metaItem {
        font-size: 13px;
    }
    
    .c-staffCard__button {
        padding: 10px;
        font-size: 14px;
    }
}

/* グリッドレイアウト - 固定列数 */
.c-staffGrid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* PC: 必ず4列 */
    gap: 30px;
    max-width: 1400px; /* 最大幅を設定 */
    margin: 0 auto; /* 中央寄せ */
}

/* タブレット表示 */
@media (max-width: 1024px) {
    .c-staffGrid {
        grid-template-columns: repeat(3, 1fr); /* タブレット: 3列 */
        gap: 24px;
    }
}

/* SP表示 */
@media (max-width: 768px) {
    .c-staffGrid {
        grid-template-columns: repeat(2, 1fr); /* SP: 必ず2列 */
        gap: 16px;
    }
    
    /* カード内の調整 */
    .c-staffCard__body {
        padding: 12px;
    }
    
    .c-staffCard__name {
        font-size: 16px;
        margin-bottom: 10px;
    }
    
    .c-staffCard__shift {
        font-size: 12px;
        margin-bottom: 10px;
    }
    
    .c-staffCard__meta {
        gap: 6px;
        margin-bottom: 12px;
    }
    
    .c-staffCard__metaItem {
        font-size: 12px;
    }
    
    .c-staffCard__button {
        padding: 8px;
        font-size: 13px;
    }
}

/* 極小画面（iPhone SE等）でも2列を維持 */
@media (max-width: 375px) {
    .c-staffGrid {
        gap: 12px;
    }
    
    .c-staffCard__body {
        padding: 10px;
    }
    
    .c-staffCard__name {
        font-size: 14px;
    }
    
    .c-staffCard__shift {
        font-size: 11px;
    }
    
    .c-staffCard__meta {
        gap: 4px;
    }
    
    .c-staffCard__metaItem {
        font-size: 11px;
    }
    
    .c-staffCard__button {
        padding: 6px;
        font-size: 12px;
    }
}