/* css/components.css */
:root {
    --accent: #f97316;
    --white: #ffffff;
    --primary-dark: #1e293b;
    --text-muted: #64748b;
    --card-shadow: 0 10px 25px rgba(0, 0, 0, 0.05);
}

/* 제목 및 설명 */
h2 { font-size: 28px; font-weight: 800; color: var(--primary-dark); margin: 0; }
.sub-title-desc { color: var(--text-muted); font-size: 15px; margin-top: 8px; }

/* 시스템 허브 카드 그리드 */
.hub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); /* 화면 너비에 따라 카드 개수 자동 조절 */
    gap: 30px;
    margin-top: 40px;
}

/* 개별 카드 디자인 */
.menu-card {
    background: var(--white);
    padding: 40px 30px;
    border-radius: 24px;
    text-align: center;
    box-shadow: var(--card-shadow);
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    border: 1px solid #f1f5f9;
    position: relative;
    overflow: hidden;
}

/* 카드 호버 효과 */
.menu-card:hover {
    transform: translateY(-10px);
    border-color: var(--accent);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
}

.card-icon {
    font-size: 50px;
    margin-bottom: 25px;
    display: block;
    filter: drop-shadow(0 5px 10px rgba(0,0,0,0.1));
}

.card-title {
    font-size: 19px;
    font-weight: 800;
    color: var(--primary-dark);
    margin-bottom: 15px;
}

.card-desc {
    font-size: 14px;
    color: var(--text-muted);
    line-height: 1.6;
    margin-bottom: 25px;
    min-height: 45px; /* 설명 칸 높이 균일화 */
}

.card-footer {
    font-size: 12px;
    color: var(--accent);
    font-weight: 700;
    padding-top: 20px;
    border-top: 1px solid #f8fafc;
    letter-spacing: 0.5px;
}

/* 섹션 가이드 라인 */
.section-title { 
    font-size: 16px; font-weight: 800; margin-bottom: 25px; color: var(--primary-dark); 
    display: flex; align-items: center; gap: 10px;
}
.section-title::before {
    content: ''; display: inline-block; width: 5px; height: 18px; 
    background: var(--accent); border-radius: 3px;
}