/**
 * @file platf_new/css/style.css
 * @brief 위아주 통합 스타일시트 (Modern Flat Design)
 *
 * platf.css + api_client main_style.css 병합
 * 네임스페이스: .ezs-container (기존 platf 호환)
 *
 * @author somevue
 * @version 2.2.251202 (Modern Flat Design)
 * @date 2025-12-02
 * @changelog
 *   - v2.2.251202: Material Design 적용, 그라데이션 제거, 접근성 개선
 *   - v2.1.251022: 초기 병합 버전
 */

/* ============================================================
   CSS 변수 (Design System)
   ============================================================ */
:root {
    /* Primary Colors (Material Blue) */
    --primary-50: #E3F2FD;
    --primary-100: #BBDEFB;
    --primary-200: #90CAF9;
    --primary-300: #64B5F6;
    --primary-400: #42A5F5;
    --primary-500: #2196F3;  /* Primary */
    --primary-600: #1E88E5;
    --primary-700: #1976D2;  /* Primary Dark */
    --primary-800: #1565C0;
    --primary-900: #0D47A1;

    /* Secondary Colors (Material Purple) */
    --secondary-500: #9C27B0;
    --secondary-700: #7B1FA2;

    /* Neutral Colors */
    --neutral-50: #FAFAFA;
    --neutral-100: #F5F5F5;
    --neutral-200: #EEEEEE;
    --neutral-300: #E0E0E0;
    --neutral-400: #BDBDBD;
    --neutral-500: #9E9E9E;
    --neutral-600: #757575;
    --neutral-700: #616161;
    --neutral-800: #424242;
    --neutral-900: #212121;

    /* Semantic Colors */
    --success: #4CAF50;
    --warning: #FF9800;
    --error: #F44336;
    --info: #2196F3;

    /* Text Colors */
    --text-primary: #212121;
    --text-secondary: #757575;
    --text-disabled: #BDBDBD;
    --text-hint: #9E9E9E;

    /* Background Colors */
    --bg-primary: #FFFFFF;
    --bg-secondary: #FAFAFA;
    --bg-tertiary: #F5F5F5;

    /* Spacing (8px base) */
    --spacing-1: 4px;
    --spacing-2: 8px;
    --spacing-3: 12px;
    --spacing-4: 16px;
    --spacing-5: 20px;
    --spacing-6: 24px;
    --spacing-8: 32px;
    --spacing-10: 40px;
    --spacing-12: 48px;

    /* Typography */
    --font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans KR", sans-serif;
    --font-size-xs: 0.875rem;    /* 12px */
    --font-size-sm: 1rem;   /* 14px */
    --font-size-base: 1.125rem;     /* 16px */
    --font-size-lg: 1.25rem;   /* 18px */
    --font-size-xl: 1.5rem;    /* 20px */
    --font-size-2xl: 2rem;    /* 24px */
    --font-size-3xl: 2.5rem;      /* 32px */
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-full: 9999px;

    /* Shadows (Material Design Elevation) */
    --shadow-1: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
    --shadow-2: 0 3px 6px rgba(0, 0, 0, 0.15), 0 2px 4px rgba(0, 0, 0, 0.12);
    --shadow-3: 0 10px 20px rgba(0, 0, 0, 0.15), 0 3px 6px rgba(0, 0, 0, 0.10);
    --shadow-4: 0 15px 25px rgba(0, 0, 0, 0.15), 0 5px 10px rgba(0, 0, 0, 0.05);
    --shadow-none: none;

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-base: 250ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 350ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================================
   공통 컨테이너
   ============================================================ */
.ezs-container {
    width: 100%;
    max-width: 1240px;
    margin: 0 auto;
    padding: var(--spacing-5);
    font-family: var(--font-family);
    color: var(--text-primary);
}

.ezs-container header {
    position: relative;
    z-index: 1;
}

.ezs-container footer {
    background: transparent;
}

/* ============================================================
   페이지 헤더 (Flat Design)
   ============================================================ */
.ezs-container .page-header {
    text-align: center;
    margin-bottom: var(--spacing-10);
    padding: var(--spacing-8) var(--spacing-5);
    background: var(--primary-700);
    color: white;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-2);
}

.ezs-container .page-header h1 {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-2);
    letter-spacing: -0.02em;
}

.ezs-container .page-description {
    font-size: var(--font-size-lg);
    opacity: 0.95;
    font-weight: var(--font-weight-regular);
}

/* ============================================================
   네비게이션
   ============================================================ */
.ezs-container .category-navigation {
    margin-bottom: var(--spacing-8);
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-1);
    overflow: hidden;
}

/* 모바일용 셀렉트박스 네비게이션 (기본 숨김) */
.ezs-container .nav-select-wrapper,
.ezs-container .category-nav-select-wrapper {
    display: none;
}

.ezs-container .nav-select,
.ezs-container .category-nav-select {
    width: 100%;
    padding: var(--spacing-3) var(--spacing-4);
    border: 2px solid var(--neutral-300);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-family);
    background: var(--bg-primary);
    color: var(--text-primary);
    cursor: pointer;
    transition: all var(--transition-fast);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23212121' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--spacing-3) center;
    background-size: 12px;
    padding-right: var(--spacing-10);
}

.ezs-container .nav-select:focus,
.ezs-container .category-nav-select:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px var(--primary-50);
}

.ezs-container .nav-select:hover,
.ezs-container .category-nav-select:hover {
    border-color: var(--primary-700);
}

.ezs-container .nav-list {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    justify-content: center;
    margin: 0;
    padding: 0;
}

.ezs-container .nav-item {
    flex: 0 0 auto;
}

.ezs-container .nav-link {
    display: block;
    padding: var(--spacing-4) var(--spacing-6);
    text-decoration: none;
    color: var(--text-secondary);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
    border-bottom: 3px solid transparent;
}

.ezs-container .nav-link:hover {
    background-color: var(--neutral-50);
    color: var(--text-primary);
}

.ezs-container .nav-item.active .nav-link {
    color: var(--primary-700);
    background-color: var(--primary-50);
    border-bottom-color: var(--primary-700);
    font-weight: var(--font-weight-semibold);
}

/* ============================================================
   검색창
   ============================================================ */
.ezs-container .search-container {
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-1);
    margin-bottom: var(--spacing-8);
    padding: var(--spacing-5);
}

.ezs-container .search-form {
    max-width: 600px;
    margin: 0 auto;
}

.ezs-container .search-input-group {
    display: flex;
    gap: var(--spacing-2);
    align-items: center;
}

.ezs-container .search-input {
    flex: 1;
    padding: var(--spacing-3) var(--spacing-4);
    border: 2px solid var(--neutral-300);
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    transition: border-color var(--transition-fast);
    font-family: var(--font-family);
}

.ezs-container .search-input:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px var(--primary-50);
}

.ezs-container .search-button {
    padding: var(--spacing-3) var(--spacing-6);
    background: var(--primary-700);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.ezs-container .search-button:hover {
    background: var(--primary-800);
    box-shadow: var(--shadow-2);
}

.ezs-container .search-button:active {
    transform: translateY(1px);
}

.ezs-container .search-clear {
    padding: var(--spacing-3) var(--spacing-4);
    background: var(--neutral-600);
    color: white;
    text-decoration: none;
    border-radius: var(--radius-md);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
}

.ezs-container .search-clear:hover {
    background: var(--neutral-700);
    color: white;
    text-decoration: none;
}

/* ============================================================
   사업 카테고리 네비게이션
   ============================================================ */
.ezs-container .category-nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding-bottom: var(--spacing-4);
}

.ezs-container .category-nav-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: var(--spacing-4);
    text-align: center;
}

.ezs-container .category-nav-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-2);
}

.ezs-container .category-nav-item {
    display: inline-block;
    padding: var(--spacing-2) var(--spacing-4);
    background: var(--neutral-100);
    color: var(--text-secondary);
    text-decoration: none;
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
    border: 2px solid transparent;
}

.ezs-container .category-nav-item:hover {
    background: var(--neutral-200);
    color: var(--text-primary);
    text-decoration: none;
    transform: translateY(-1px);
}

.ezs-container .category-nav-item.active {
    background: var(--primary-700);
    color: white;
    border-color: var(--primary-700);
    box-shadow: var(--shadow-2);
}

/* ============================================================
   에러 메시지
   ============================================================ */
.ezs-container .error-message {
    background: #FFEBEE;
    color: #C62828;
    padding: var(--spacing-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-5);
    border: 1px solid #EF9A9A;
    font-weight: var(--font-weight-medium);
}

/* ============================================================
   프라이버시 비공개 표시
   ============================================================ */
.ezs-container .privacy-masked {
    color: var(--text-disabled);
    font-style: italic;
    font-size: var(--font-size-sm);
}

/* ============================================================
   회원 그리드 (목록 페이지)
   ============================================================ */
.ezs-container .member-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-5);
    margin-bottom: var(--spacing-10);
}

/* 컬럼 수 조정 클래스 */
.ezs-container .member-grid-2cols { grid-template-columns: repeat(2, 1fr); }
.ezs-container .member-grid-3cols { grid-template-columns: repeat(3, 1fr); }
.ezs-container .member-grid-4cols { grid-template-columns: repeat(4, 1fr); }
.ezs-container .member-grid-5cols { grid-template-columns: repeat(5, 1fr); }

.ezs-container .member-card {
    background: var(--bg-primary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-1);
    overflow: hidden;
    transition: all var(--transition-base);
    cursor: pointer;
    border: 1px solid var(--neutral-200);
}

.ezs-container .member-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-3);
    border-color: var(--neutral-300);
}

.ezs-container .member-thumbnail {
    width: 100%;
    min-height: 100px;
    overflow: hidden;
    background: var(--neutral-100);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ezs-container .thumbnail-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.ezs-container .member-card:hover .thumbnail-img {
    transform: scale(1.05);
}

.ezs-container .thumbnail-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--neutral-200);
}

.ezs-container .placeholder-text {
    color: var(--text-disabled);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
}

.ezs-container .member-info {
    padding: var(--spacing-5);
}

.ezs-container .company-name {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin-bottom: var(--spacing-2);
    line-height: 1.4;
}

.ezs-container .company-intro {
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
    line-height: 1.6;
    margin-bottom: var(--spacing-4);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ezs-container .member-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.ezs-container .name-position {
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    font-size: var(--font-size-base);
}

.ezs-container .business-category {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    margin-top: var(--spacing-2);
}

/* ============================================================
   페이징
   ============================================================ */
.ezs-container .pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-1);
    margin-top: var(--spacing-10);
}

.ezs-container .page-link {
    display: inline-block;
    width: auto;
    height: auto;
    line-height: normal;
    padding: var(--spacing-2) var(--spacing-4);
    text-decoration: none;
    color: var(--text-secondary);
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
    font-weight: var(--font-weight-medium);
    background: var(--bg-primary);
}

.ezs-container .page-link:hover {
    background-color: var(--primary-700);
    color: white;
    border-color: var(--primary-700);
}

.ezs-container .page-link.current {
    background-color: var(--primary-700);
    color: white;
    border-color: var(--primary-700);
    font-weight: var(--font-weight-semibold);
}

.ezs-container .page-link.prev,
.ezs-container .page-link.next {
    font-weight: var(--font-weight-semibold);
}

/* ============================================================
   데이터 없음
   ============================================================ */
.ezs-container .no-data {
    text-align: center;
    padding: var(--spacing-12) var(--spacing-5);
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-1);
}

.ezs-container .no-data p {
    font-size: var(--font-size-lg);
    color: var(--text-secondary);
}

/* ============================================================
   메인 인클루드 스타일 - 그리드
   ============================================================ */
.ezs-container .main-member-section {
    margin: var(--spacing-8) 0;
}

.ezs-container .main-member-title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-6);
    color: var(--text-primary);
}

.ezs-container .main-member-grid {
    display: grid;
    gap: var(--spacing-6);
    grid-auto-rows: 1fr;
}

.ezs-container .main-member-grid-2cols { grid-template-columns: repeat(2, 1fr); }
.ezs-container .main-member-grid-3cols { grid-template-columns: repeat(3, 1fr); }
.ezs-container .main-member-grid-4cols { grid-template-columns: repeat(4, 1fr); }
.ezs-container .main-member-grid-5cols { grid-template-columns: repeat(5, 1fr); }

.ezs-container .main-member-card {
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-1);
    cursor: pointer;
    transition: all var(--transition-base);
    display: flex;
    flex-direction: column;
    height: 100%;
    border: 1px solid var(--neutral-200);
}

.ezs-container .main-member-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-3);
    border-color: var(--neutral-300);
}

.ezs-container .main-member-thumbnail {
    width: 100%;
    min-height: 100px;
    overflow: hidden;
    background: var(--neutral-100);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.ezs-container .main-member-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ezs-container .main-member-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-700);
    color: white;
    font-size: var(--font-size-base);
}

.ezs-container .main-member-info {
    padding: var(--spacing-4);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.ezs-container .main-member-company {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-bold);
    margin: 0 0 var(--spacing-2) 0;
    color: var(--text-primary);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.5rem;
}

.ezs-container .main-member-intro {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin: 0 0 var(--spacing-3) 0;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}

.ezs-container .main-member-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-sm);
    margin-top: auto;
}

.ezs-container .main-member-name {
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
}

.ezs-container .main-member-category {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    margin-top: var(--spacing-2);
}

/* v2.2: Badge 스타일 (Material Design) */
.ezs-container .category-badge {
    display: inline-block;
    padding: 3px 8px;
    background: var(--primary-700);
    color: white;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    transition: background var(--transition-fast);
}

.ezs-container .category-badge:hover {
    background: var(--primary-800);
}

.ezs-container .tag-badge {
    display: inline-block;
    padding: 2px 4px;
    color: var(--success);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-xs);
    transition: color var(--transition-fast);
}

.ezs-container .tag-badge:hover {
    color: #2E7D32;
}

/* v2.3: Platform Category Labels (Pastel 톤) */
.ezs-container .platform-categories {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-1);
    margin-top: var(--spacing-2);
}

.ezs-container .category-label {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.ezs-container .category-label-1 {
    background: #E3F2FD; /* Pastel Blue */
    color: #1565C0;
    border: 1px solid #BBDEFB;
}

.ezs-container .category-label-1:hover {
    background: #BBDEFB;
}

.ezs-container .category-label-2 {
    background: #E8F5E9; /* Pastel Green */
    color: #2E7D32;
    border: 1px solid #C8E6C9;
}

.ezs-container .category-label-2:hover {
    background: #C8E6C9;
}

.ezs-container .category-label-3 {
    background: #F3E5F5; /* Pastel Purple */
    color: #6A1B9A;
    border: 1px solid #E1BEE7;
}

.ezs-container .category-label-3:hover {
    background: #E1BEE7;
}

/* ============================================================
   메인 인클루드 - 리스트
   ============================================================ */
.ezs-container .main-member-list {
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.ezs-container .main-member-list-item {
    display: flex;
    align-items: center;
    padding: var(--spacing-4);
    border-bottom: 1px solid var(--neutral-200);
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

.ezs-container .main-member-list-item:last-child {
    border-bottom: none;
}

.ezs-container .main-member-list-item:hover {
    background-color: var(--neutral-50);
}

.ezs-container .main-member-list-thumb {
    width: 60px;
    height: 60px;
    border-radius: var(--radius-full);
    overflow: hidden;
    margin-right: var(--spacing-4);
    flex-shrink: 0;
}

.ezs-container .main-member-list-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ezs-container .main-member-list-info h3 {
    margin: 0 0 var(--spacing-1) 0;
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
}

.ezs-container .main-member-list-info p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

/* ============================================================
   메인 인클루드 - 컴팩트
   ============================================================ */
.ezs-container .main-member-compact {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.ezs-container .main-member-compact-item {
    border-bottom: 1px solid var(--neutral-200);
}

.ezs-container .main-member-compact-item:last-child {
    border-bottom: none;
}

.ezs-container .main-member-compact-item a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-3) var(--spacing-4);
    text-decoration: none;
    transition: background-color var(--transition-fast);
}

.ezs-container .main-member-compact-item a:hover {
    background-color: var(--neutral-50);
}

.ezs-container .main-member-compact-item .name {
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    margin-right: var(--spacing-4);
}

.ezs-container .main-member-compact-item .company {
    flex: 1;
    color: var(--text-secondary);
}

.ezs-container .main-member-compact-item .position {
    color: var(--text-hint);
    font-size: var(--font-size-sm);
}

/* ============================================================
   메인 인클루드 - 슬라이더
   ============================================================ */
.ezs-container .main-member-slider-style {
    position: relative;
}

.ezs-container .main-member-slider-style .swiper {
    padding: 0 40px;
}

.ezs-container .main-member-slider-style .swiper-wrapper {
    align-items: stretch;
}

.ezs-container .main-member-slider-style .swiper-slide {
    height: auto;
    display: flex;
    align-items: stretch;
}

.ezs-container .main-member-slide-card {
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-1);
    cursor: pointer;
    transition: all var(--transition-base);
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 380px;
    border: 1px solid var(--neutral-200);
}

.ezs-container .main-member-slide-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-3);
    border-color: var(--neutral-300);
}

.ezs-container .main-member-slide-thumb {
    width: 100%;
    min-height: 100px;
    overflow: hidden;
    background: var(--neutral-100);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.ezs-container .main-member-slide-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ezs-container .main-member-slide-info {
    padding: var(--spacing-4);
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 150px;
}

.ezs-container .main-member-slide-info h3 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-bold);
    margin: 0 0 var(--spacing-2) 0;
    color: var(--text-primary);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.5rem;
}

.ezs-container .main-member-slide-info .intro {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin: 0 0 var(--spacing-2) 0;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}

.ezs-container .main-member-slide-info .name {
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    margin: 0;
    padding-top: var(--spacing-2);
    border-top: 1px solid var(--neutral-200);
}

.ezs-container .swiper-button-next,
.ezs-container .swiper-button-prev {
    color: var(--primary-700);
}

.ezs-container .swiper-pagination-bullet-active {
    background: var(--primary-700);
}

/* ============================================================
   view_post 스타일 (블로그 포스트 형식)
   ============================================================ */

/* 페이지 헤더 (view_post용) */
.ezs-container .platfmgmt-post-wrapper {
    margin: 0;
    padding: 0;
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: 1.8;
    color: var(--text-primary);
    background-color: var(--bg-primary);
}

.ezs-container .platfmgmt-post-wrapper * {
    box-sizing: border-box;
}

.ezs-container .platfmgmt-post-wrapper img {
    max-width: 100%;
    height: auto;
}

.ezs-container .platfmgmt-post-wrapper a {
    color: var(--primary-700);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.ezs-container .platfmgmt-post-wrapper a:hover {
    color: var(--primary-800);
    text-decoration: underline;
}

.ezs-container .platfmgmt-post-wrapper .post-header {
    background: var(--primary-700);
    color: white;
    padding: var(--spacing-5);
    text-align: center;
    box-shadow: var(--shadow-1);
}

.ezs-container .platfmgmt-post-wrapper .post-header-content {
    max-width: 1200px;
    margin: 0 auto;
}

.ezs-container .page-header .post-header-content {
    max-width: 1200px;
    margin: 0 auto;
}

.ezs-container .page-header .post-title {
    margin: 0;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-semibold);
    letter-spacing: -0.01em;
    color: white;
}

.ezs-container .page-header .post-platform-info {
    margin-top: var(--spacing-3);
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--spacing-3);
}

.ezs-container .page-header .platform-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    backdrop-filter: blur(10px);
}

.ezs-container .page-header .platform-badge i {
    font-size: var(--font-size-sm);
}

/* 메인 컨텐츠 */
.ezs-container .platfmgmt-post-wrapper .post-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--spacing-8) 0;
}

.ezs-container .platfmgmt-post-wrapper .post-section {
    margin-bottom: var(--spacing-12);
}

/* 콜아웃 섹션 */
.ezs-container .platfmgmt-post-wrapper .callout {
    background-color: var(--primary-50);
    border-left: 4px solid var(--primary-700);
    padding: var(--spacing-8);
    border-radius: var(--radius-sm);
}

.ezs-container .platfmgmt-post-wrapper .callout-content {
    font-size: var(--font-size-lg);
    line-height: 1.8;
}

.ezs-container .platfmgmt-post-wrapper .callout-content p {
    margin: 0.5em 0;
}

.ezs-container .platfmgmt-post-wrapper .callout-content strong {
    color: var(--primary-700);
    font-weight: var(--font-weight-semibold);
}

/* 유튜브 섹션 */
.ezs-container .platfmgmt-post-wrapper .youtube-wrapper {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    background-color: #000;
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.ezs-container .platfmgmt-post-wrapper .youtube-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* 상세 컨텐츠 섹션 */
.ezs-container .platfmgmt-post-wrapper .detail-content {
    background-color: var(--bg-primary);
    padding: var(--spacing-8);
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-md);
}

.ezs-container .platfmgmt-post-wrapper .detail-content h2 {
    margin: 0 0 var(--spacing-5) 0;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    border-bottom: 2px solid var(--neutral-300);
    padding-bottom: var(--spacing-3);
}

.ezs-container .platfmgmt-post-wrapper .detail-content h3 {
    margin: var(--spacing-5) 0 var(--spacing-3) 0;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
}

.ezs-container .platfmgmt-post-wrapper .detail-content p {
    margin: 0.8em 0;
    line-height: 1.8;
}

.ezs-container .platfmgmt-post-wrapper .detail-content ul,
.ezs-container .platfmgmt-post-wrapper .detail-content ol {
    margin: var(--spacing-5) 0;
    padding-left: var(--spacing-8);
}

.ezs-container .platfmgmt-post-wrapper .detail-content li {
    margin: 0.5em 0;
    line-height: 1.6;
}

.ezs-container .platfmgmt-post-wrapper .detail-content blockquote {
    margin: var(--spacing-5) 0;
    padding: var(--spacing-5) var(--spacing-8);
    background-color: var(--neutral-100);
    border-left: 4px solid var(--neutral-600);
    border-radius: var(--radius-sm);
    font-style: italic;
}

/* 정보 그리드 */
.ezs-container .platfmgmt-post-wrapper .info-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-5);
}

.ezs-container .platfmgmt-post-wrapper .info-card {
    background-color: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-1);
    overflow: hidden;
    transition: all var(--transition-fast);
    border: 1px solid var(--neutral-200);
}

.ezs-container .platfmgmt-post-wrapper .info-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-2);
    border-color: var(--neutral-300);
}

.ezs-container .platfmgmt-post-wrapper .info-card.full-width {
    grid-column: 1 / -1;
}

.ezs-container .platfmgmt-post-wrapper .card-title {
    margin: 0;
    padding: var(--spacing-5);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    background-color: var(--neutral-100);
    border-bottom: 1px solid var(--neutral-300);
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.ezs-container .platfmgmt-post-wrapper .card-title i {
    color: var(--primary-700);
    font-size: var(--font-size-base);
}

.ezs-container .platfmgmt-post-wrapper .card-content {
    padding: var(--spacing-5);
}

/* 정보 테이블 */
.ezs-container .platfmgmt-post-wrapper .info-table {
    width: 100%;
    border-collapse: collapse;
}

.ezs-container .platfmgmt-post-wrapper .info-table tr {
    border-bottom: 1px solid var(--neutral-200);
}

.ezs-container .platfmgmt-post-wrapper .info-table tr:last-child {
    border-bottom: none;
}

.ezs-container .platfmgmt-post-wrapper .info-table th {
    padding: var(--spacing-3) var(--spacing-5);
    text-align: left;
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
    width: 100px;
    vertical-align: top;
}

.ezs-container .platfmgmt-post-wrapper .info-table td {
    padding: var(--spacing-3) var(--spacing-5);
    color: var(--text-primary);
}

/* 업종 정보 */
.ezs-container .platfmgmt-post-wrapper .category-item {
    margin-bottom: var(--spacing-5);
}

.ezs-container .platfmgmt-post-wrapper .category-item:last-child {
    margin-bottom: 0;
}

.ezs-container .platfmgmt-post-wrapper .category-path {
    margin-bottom: var(--spacing-3);
    font-size: var(--font-size-sm);
}

.ezs-container .platfmgmt-post-wrapper .large-cat {
    color: var(--text-secondary);
    font-weight: var(--font-weight-semibold);
}

.ezs-container .platfmgmt-post-wrapper .separator {
    margin: 0 0.5rem;
    color: var(--text-hint);
}

.ezs-container .platfmgmt-post-wrapper .medium-cat {
    color: var(--text-primary);
    font-weight: var(--font-weight-semibold);
}

.ezs-container .platfmgmt-post-wrapper .tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
}

.ezs-container .platfmgmt-post-wrapper .tag {
    display: inline-block;
    padding: 4px 10px;
    font-size: var(--font-size-sm);
    background-color: var(--neutral-100);
    border: 1px solid var(--neutral-300);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
}

/* SNS 링크 */
.ezs-container .platfmgmt-post-wrapper .sns-links {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--spacing-3);
}

.ezs-container .platfmgmt-post-wrapper .sns-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-5);
    background-color: var(--neutral-100);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
    text-decoration: none;
    box-shadow: var(--shadow-1);
}

.ezs-container .platfmgmt-post-wrapper .sns-link:hover {
    background-color: var(--primary-700);
    color: white;
    transform: translateY(-2px);
    box-shadow: var(--shadow-2);
    text-decoration: none;
}

.ezs-container .platfmgmt-post-wrapper .sns-link i {
    font-size: var(--font-size-lg);
    color: var(--primary-700);
    transition: color var(--transition-fast);
}

.ezs-container .platfmgmt-post-wrapper .sns-link:hover i {
    color: white;
}

.ezs-container .platfmgmt-post-wrapper .sns-name {
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
    transition: color var(--transition-fast);
}

.ezs-container .platfmgmt-post-wrapper .sns-link:hover .sns-name {
    color: white;
}

/* 주소 정보 */
.ezs-container .platfmgmt-post-wrapper .address-info {
    margin-bottom: var(--spacing-5);
}

.ezs-container .platfmgmt-post-wrapper .address-item {
    display: flex;
    margin-bottom: var(--spacing-3);
}

.ezs-container .platfmgmt-post-wrapper .address-label {
    min-width: 80px;
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
}

.ezs-container .platfmgmt-post-wrapper .address-value {
    flex: 1;
    color: var(--text-primary);
}

/* 카카오맵 */
.ezs-container .platfmgmt-post-wrapper .kakao-map {
    width: 100%;
    height: 400px;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-1);
}

/* 푸터 */
.ezs-container .platfmgmt-post-wrapper .post-footer {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--spacing-8) var(--spacing-5);
    text-align: center;
    display: flex;
    justify-content: center;
    gap: var(--spacing-5);
}

.ezs-container .platfmgmt-post-wrapper .post-footer button {
    padding: var(--spacing-3) var(--spacing-8);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.ezs-container .platfmgmt-post-wrapper .btn-back {
    background-color: var(--primary-700);
    color: white;
}

.ezs-container .platfmgmt-post-wrapper .btn-back:hover {
    background-color: var(--primary-800);
    transform: translateY(-2px);
}

/* ============================================================
   반응형 디자인
   ============================================================ */
@media (max-width: 1280px) {
    .ezs-container .main-member-grid-5cols {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 1200px) {
    .ezs-container .member-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 1024px) {
    .ezs-container .main-member-grid-4cols,
    .ezs-container .main-member-grid-5cols {
        grid-template-columns: repeat(3, 1fr);
    }

    .ezs-container .page-header .post-title {
        font-size: var(--font-size-xl);
    }

    .ezs-container .page-header .post-platform-info {
        font-size: var(--font-size-sm);
    }

    .ezs-container .platfmgmt-post-wrapper .sns-links {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .ezs-container {
        padding: var(--spacing-4);
    }

    .ezs-container .page-header h1 {
        font-size: var(--font-size-3xl);
    }

    .ezs-container .member-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-4);
    }

    .ezs-container .main-member-grid-3cols,
    .ezs-container .main-member-grid-4cols,
    .ezs-container .main-member-grid-5cols {
        grid-template-columns: repeat(2, 1fr);
    }

    .ezs-container .main-member-thumbnail,
    .ezs-container .main-member-slide-thumb {
        min-height: 100px;
    }

    /* 모바일: 기존 네비게이션 숨기기 */
    .ezs-container .nav-list {
        display: none;
    }

    .ezs-container .category-nav-list {
        display: none;
    }

    /* 모바일: 셀렉트박스 네비게이션 표시 */
    .ezs-container .nav-select-wrapper,
    .ezs-container .category-nav-select-wrapper {
        display: block;
    }

    .ezs-container .pagination {
        flex-wrap: wrap;
        gap: var(--spacing-1);
    }

    .ezs-container .page-link {
        padding: var(--spacing-2) var(--spacing-3);
        font-size: var(--font-size-sm);
    }

    .ezs-container .search-input-group {
        flex-direction: column;
        gap: var(--spacing-2);
    }

    .ezs-container .search-input {
        width: 100%;
    }

    .ezs-container .search-button,
    .ezs-container .search-clear {
        width: 100%;
        text-align: center;
    }

    .ezs-container .page-header .post-title {
        font-size: var(--font-size-xl);
    }

    .ezs-container .platfmgmt-post-wrapper .info-table th {
        width: 100px;
    }

    .ezs-container .platfmgmt-post-wrapper .sns-links {
        grid-template-columns: repeat(2, 1fr);
    }

    /* 모바일: 셀렉트박스 네비게이션 표시 */
    .ezs-container .nav-select-wrapper,
    .ezs-container .category-nav-select-wrapper {
        display: block;
    }
}

@media (max-width: 480px) {
    .ezs-container .member-grid {
        grid-template-columns: 1fr;
    }

    .ezs-container .main-member-grid {
        grid-template-columns: 1fr;
    }

    .ezs-container .main-member-slider-style .swiper {
        padding: 0 30px;
    }

    .ezs-container .page-header {
        padding: var(--spacing-5) 0;
    }

    .ezs-container .page-header h1 {
        font-size: var(--font-size-2xl);
    }

    .ezs-container .member-thumbnail {
        min-height: 100px;
    }

    .ezs-container .member-info {
        padding: var(--spacing-4);
    }

    .ezs-container .company-name {
        font-size: var(--font-size-lg);
    }

    .ezs-container .page-header .post-title {
        font-size: var(--font-size-lg);
    }

    .ezs-container .page-header .post-platform-info {
        flex-direction: column;
        align-items: center;
    }

    .ezs-container .platfmgmt-post-wrapper .info-table th {
        width: 80px;
        font-size: var(--font-size-sm);
    }

    .ezs-container .platfmgmt-post-wrapper .info-table td {
        font-size: var(--font-size-sm);
    }

    .ezs-container .platfmgmt-post-wrapper .sns-links {
        grid-template-columns: 1fr;
    }

    .ezs-container .platfmgmt-post-wrapper .kakao-map {
        height: 300px;
    }

    .ezs-container .platfmgmt-post-wrapper .post-footer {
        flex-direction: column;
    }

    .ezs-container .platfmgmt-post-wrapper .post-footer button {
        width: 100%;
    }
}

/* ============================================================
   인쇄 스타일
   ============================================================ */
@media print {
    .ezs-container .platfmgmt-post-wrapper {
        background-color: white;
    }

    .ezs-container .platfmgmt-post-wrapper .post-header,
    .ezs-container .page-header {
        background: none;
        color: black;
        box-shadow: none;
        border-bottom: 2px solid #000;
    }

    .ezs-container .platfmgmt-post-wrapper .post-footer {
        display: none !important;
    }

    .ezs-container .platfmgmt-post-wrapper .info-card {
        page-break-inside: avoid;
        border: 1px solid var(--neutral-300);
    }

    .ezs-container .platfmgmt-post-wrapper .kakao-map {
        display: none;
    }
}

/* ============================================================
   위젯 예제 페이지 스타일 (widget_example.php)
   v2.5.0 - 2025-12-05
   ============================================================ */

/* 위젯 페이지 전용 변수 */
.weajou-widget-section {
    --widget-primary: #667eea;
    --widget-secondary: #764ba2;
    --widget-success: #2ecc71;
    --widget-info: #3498db;
    --widget-warning: #f39c12;
    --widget-danger: #e74c3c;
}

/* 위젯 페이지 Body 스타일 */
.weajou-widget-section {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    margin: 0;
    padding: 20px 0;
    color: #333;
    min-height: 100px;
}

/* 위젯 페이지 헤더 */
.weajou-widget-section .page-header {
    text-align: center;
    margin-bottom: 40px;
    background: white;
    padding: 30px;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.weajou-widget-section .page-header h1 {
    margin: 0 0 10px;
    color: #2c3e50;
    font-size: 2rem;
}

.weajou-widget-section .page-header p {
    color: #666;
    margin: 0;
    font-size: 1.1rem;
}

.weajou-widget-section .version-badge {
    display: inline-block;
    background: linear-gradient(135deg, var(--widget-primary), var(--widget-secondary));
    color: white;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    margin-left: 10px;
}

/* 위젯 컨테이너 (CSS Grid) */
.weajou-widget-section .widget-container {
    max-width: 1400px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 20px;
    align-items: start;
}

/* 공통 위젯 박스 스타일 */
.weajou-widget-section .widget-box {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    padding: 24px;
    overflow: hidden;
    transition: all 0.3s ease;
    border: 2px solid transparent;
    position: relative;
}

.weajou-widget-section .widget-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--widget-primary), var(--widget-secondary));
    opacity: 0;
    transition: opacity 0.3s ease;
}

.weajou-widget-section .widget-box:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
    border-color: var(--widget-primary);
}

.weajou-widget-section .widget-box:hover::before {
    opacity: 1;
}

/* 위젯 크기 변형 */
.weajou-widget-section .widget-full {
    grid-column: 1 / -1;
}

.weajou-widget-section .widget-large {
    grid-column: span 2;
}

/* 위젯 헤더 */
.weajou-widget-section .widget-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 2px solid #f0f0f0;
}

.weajou-widget-section .widget-title {
    font-size: 24px;
    font-weight: 700;
    color: #2c3e50;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.weajou-widget-section .widget-title i {
    font-size: 20px;
}

.weajou-widget-section .widget-subtitle {
    font-size: 12px;
    color: #999;
    font-weight: 400;
    margin-left: 8px;
}

.weajou-widget-section .widget-more {
    font-size: 13px;
    color: var(--widget-primary);
    text-decoration: none;
    transition: color 0.2s;
    font-weight: 600;
}

.weajou-widget-section .widget-more:hover {
    color: var(--widget-secondary);
}

.weajou-widget-section .filter-badge {
    display: inline-block;
    background: #f0f0f0;
    color: #666;
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 12px;
    margin-left: 6px;
    font-weight: 500;
}

/* --- 라이브러리 스타일 오버라이드 --- */
.weajou-widget-section .widget-box .main-member-title {
    display: none;
}

/* Compact Style Override */
.weajou-widget-section .widget-box .main-member-compact {
    padding: 0;
    margin: 0;
    list-style: none;
}

.weajou-widget-section .widget-box .main-member-compact-item {
    padding: 12px 0;
    border-bottom: 1px solid #f5f5f5;
    transition: background 0.2s;
}

.weajou-widget-section .widget-box .main-member-compact-item:hover {
    background: #f9f9f9;
    margin: 0 -12px;
    padding-left: 12px;
    padding-right: 12px;
    border-radius: 8px;
}

.weajou-widget-section .widget-box .main-member-compact-item:last-child {
    border-bottom: none;
}

.weajou-widget-section .widget-box .main-member-compact-item a {
    text-decoration: none;
    color: inherit;
    display: block;
}

.weajou-widget-section .widget-box .main-member-compact-item .name {
    font-weight: 700;
    font-size: 14px;
    color: #2c3e50;
}

.weajou-widget-section .widget-box .main-member-compact-item .company {
    font-size: 13px;
    color: #7f8c8d;
    margin-left: 6px;
}

.weajou-widget-section .widget-box .main-member-compact-item .position {
    font-size: 12px;
    color: #95a5a6;
    margin-left: 4px;
}

/* Grid Style Override */
.weajou-widget-section .widget-box .main-member-grid {
    display: grid;
    gap: 14px;
}

.weajou-widget-section .widget-box .main-member-grid-2cols {
    grid-template-columns: repeat(2, 1fr);
}

.weajou-widget-section .widget-box .main-member-grid-3cols {
    grid-template-columns: repeat(3, 1fr);
}

.weajou-widget-section .widget-box .main-member-grid-4cols {
    grid-template-columns: repeat(4, 1fr);
}

.weajou-widget-section .widget-box .main-member-grid-5cols {
    grid-template-columns: repeat(5, 1fr);
}

.weajou-widget-section .widget-box .main-member-card {
    border: 1px solid #e8e8e8;
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s;
}

.weajou-widget-section .widget-box .main-member-card:hover {
    border-color: var(--widget-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}

.weajou-widget-section .widget-box .main-member-thumbnail {
    height: 120px;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.weajou-widget-section .widget-box .main-member-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.weajou-widget-section .widget-box .main-member-placeholder {
    color: #bbb;
    font-size: 12px;
}

.weajou-widget-section .widget-box .main-member-info {
    padding: 12px;
}

.weajou-widget-section .widget-box .main-member-company {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 6px 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #2c3e50;
}

.weajou-widget-section .widget-box .main-member-intro {
    font-size: 12px;
    color: #7f8c8d;
    margin: 6px 0;
    line-height: 1.4;
}

.weajou-widget-section .widget-box .main-member-name {
    font-size: 12px;
    color: #95a5a6;
}

.weajou-widget-section .widget-box .main-member-details {
    margin-top: 8px;
}

.weajou-widget-section .widget-box .main-member-category {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 8px;
}

/* List Style Override */
.weajou-widget-section .widget-box .main-member-list-item {
    display: flex;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid #f5f5f5;
    cursor: pointer;
    transition: background 0.2s;
}

.weajou-widget-section .widget-box .main-member-list-item:hover {
    background: #f9f9f9;
    margin: 0 -12px;
    padding-left: 12px;
    padding-right: 12px;
    border-radius: 8px;
}

.weajou-widget-section .widget-box .main-member-list-item:last-child {
    border-bottom: none;
}

.weajou-widget-section .widget-box .main-member-list-thumb {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    overflow: hidden;
    margin-right: 14px;
    flex-shrink: 0;
    background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
}

.weajou-widget-section .widget-box .main-member-list-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.weajou-widget-section .widget-box .main-member-list-info h3 {
    font-size: 15px;
    font-weight: 600;
    margin: 0 0 4px 0;
    color: #2c3e50;
}

.weajou-widget-section .widget-box .main-member-list-info p {
    font-size: 13px;
    color: #7f8c8d;
    margin: 0;
}

/* Slider Override */
.weajou-widget-section .widget-box .swiper {
    padding-bottom: 30px;
}

.weajou-widget-section .widget-box .swiper-button-next,
.weajou-widget-section .widget-box .swiper-button-prev {
    color: var(--widget-primary);
    width: 30px;
    height: 30px;
}

.weajou-widget-section .widget-box .swiper-button-next::after,
.weajou-widget-section .widget-box .swiper-button-prev::after {
    font-size: 16px;
}

.weajou-widget-section .widget-box .swiper-pagination-bullet-active {
    background: var(--widget-primary);
}

/* 사용법 안내 */
.weajou-widget-section .usage-guide {
    max-width: 1400px;
    margin: 40px auto;
    background: white;
    padding: 30px;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.weajou-widget-section .usage-guide h3 {
    margin-top: 0;
    color: #2c3e50;
    font-size: 1.5rem;
}

.weajou-widget-section .usage-guide h4 {
    color: var(--widget-primary);
    margin-top: 20px;
}

.weajou-widget-section .usage-guide pre {
    background: #f8f9fa;
    padding: 15px;
    border-radius: 8px;
    font-size: 13px;
    overflow-x: auto;
    border-left: 4px solid var(--widget-primary);
}

.weajou-widget-section .usage-guide table {
    width: 100%;
    border-collapse: collapse;
    margin: 15px 0;
}

.weajou-widget-section .usage-guide th,
.weajou-widget-section .usage-guide td {
    padding: 10px;
    text-align: left;
    border-bottom: 1px solid #eee;
}

.weajou-widget-section .usage-guide th {
    background: #f8f9fa;
    font-weight: 600;
    color: #2c3e50;
}

.weajou-widget-section .usage-guide ul {
    line-height: 1.8;
}

/* 위젯 아이콘 색상 클래스 */
.weajou-widget-section .icon-info { color: var(--widget-info) !important; }
.weajou-widget-section .icon-secondary { color: var(--widget-secondary) !important; }
.weajou-widget-section .icon-warning { color: var(--widget-warning) !important; }
.weajou-widget-section .icon-success { color: var(--widget-success) !important; }
.weajou-widget-section .icon-danger { color: var(--widget-danger) !important; }
.weajou-widget-section .icon-star { color: #f1c40f !important; }
.weajou-widget-section .icon-purple { color: #9b59b6 !important; }
.weajou-widget-section .icon-red { color: #ff6b6b !important; }
.weajou-widget-section .icon-blue { color: #3498db !important; }
.weajou-widget-section .icon-orange { color: #f39c12 !important; }
.weajou-widget-section .icon-gray { color: #95a5a6 !important; }

/* 위젯 페이지 전용 유틸리티 클래스 */
.weajou-widget-section .main-member-category-block {
    display: block;
    margin-top: 4px;
}

.weajou-widget-section .no-results-message {
    padding: 20px;
    text-align: center;
    color: #888;
    background: #f8f9fa;
    border-radius: 8px;
    margin: 20px 0;
}

/* 위젯 페이지 반응형 */
@media (max-width: 1024px) {
    .weajou-widget-section .widget-large {
        grid-column: span 1;
    }
}

@media (max-width: 768px) {
    .weajou-widget-section .widget-container {
        grid-template-columns: 1fr;
    }

    .weajou-widget-section .widget-box .main-member-grid-3cols,
    .weajou-widget-section .widget-box .main-member-grid-4cols {
        grid-template-columns: repeat(2, 1fr);
    }
}
