/**
 * YAMELOG Compare Page Styles
 *
 * 比較ページ。サービス選択フォーム、比較テーブル（横スクロール対応）、CTA。
 * モバイルファースト設計。
 *
 * Classes from:
 *   - page-compare.php
 *   - template-parts/content-comparison-table.php
 *
 * @package Yamelog
 * @since 1.0.0
 */

/* ==========================================================================
   Compare Page Container (page-compare.php)
   ========================================================================== */

.ym-compare-page {
    padding-top: var(--ym-space-6);
    padding-bottom: var(--ym-space-8);
}

/* ==========================================================================
   Compare Page Header
   ========================================================================== */

.ym-compare-page__header {
    padding: var(--ym-space-6) 0;
    border-bottom: 1px solid var(--ym-color-border);
    margin-bottom: var(--ym-space-6);
}

@media (min-width: 768px) {
    .ym-compare-page__header {
        padding: var(--ym-space-8) 0;
        margin-bottom: var(--ym-space-8);
    }
}

.ym-compare-page__title {
    font-size: var(--ym-font-size-xl);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
    margin: 0 0 var(--ym-space-2);
}

@media (min-width: 768px) {
    .ym-compare-page__title {
        font-size: var(--ym-font-size-2xl);
    }
}

.ym-compare-page__subtitle {
    font-size: var(--ym-font-size-sm);
    color: var(--ym-color-text-light);
    margin: 0;
}

/* ==========================================================================
   Compare Selector (service selection form)
   ========================================================================== */

.ym-compare-page__selector {
    margin-bottom: var(--ym-space-8);
    padding: var(--ym-space-4);
    background-color: var(--ym-color-bg-gray);
    border: 1px solid var(--ym-color-border);
    border-radius: var(--ym-radius-md);
}

@media (min-width: 768px) {
    .ym-compare-page__selector {
        padding: var(--ym-space-6);
    }
}

.ym-compare-page__form {
    display: flex;
    flex-direction: column;
    gap: var(--ym-space-4);
}

.ym-compare-page__select-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ym-space-4);
}

@media (min-width: 768px) {
    .ym-compare-page__select-row {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ym-compare-page__select-group {
    display: flex;
    flex-direction: column;
    gap: var(--ym-space-2);
}

.ym-compare-page__select-label {
    font-size: var(--ym-font-size-xs);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
}

.ym-compare-page__select {
    padding: var(--ym-space-2) var(--ym-space-3);
    font-size: var(--ym-font-size-sm);
    font-family: var(--ym-font-main);
    color: var(--ym-color-text);
    background-color: var(--ym-color-bg);
    border: 1px solid var(--ym-color-border);
    border-radius: var(--ym-radius-sm);
    width: 100%;
    cursor: pointer;
    transition: border-color var(--ym-transition-fast);
}

.ym-compare-page__select:focus {
    outline: none;
    border-color: var(--ym-color-primary);
    box-shadow: 0 0 0 2px var(--ym-color-primary-light);
}

.ym-compare-page__submit {
    align-self: flex-start;
}

/* ==========================================================================
   Compare Page CTAs
   ========================================================================== */

.ym-compare-page__ctas {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ym-space-4);
    margin-top: var(--ym-space-6);
}

@media (min-width: 768px) {
    .ym-compare-page__ctas {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ym-compare-page__cta-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--ym-space-3);
    padding: var(--ym-space-4);
    background-color: var(--ym-color-bg);
    border: 1px solid var(--ym-color-border);
    border-radius: var(--ym-radius-md);
    text-align: center;
}

.ym-compare-page__cta-name {
    font-size: var(--ym-font-size-base);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
    margin: 0;
}

/* ==========================================================================
   Compare Page Empty State
   ========================================================================== */

.ym-compare-page__empty {
    text-align: center;
    padding: var(--ym-space-16) var(--ym-space-4);
}

.ym-compare-page__empty-text {
    font-size: var(--ym-font-size-sm);
    color: var(--ym-color-text-light);
    margin: 0;
}

/* ==========================================================================
   Comparison Table (content-comparison-table.php)
   ========================================================================== */

.ym-compare {
    margin-bottom: var(--ym-space-8);
}

/* ---------- Horizontal Scroll Wrapper ---------- */

.ym-compare__scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border: 1px solid var(--ym-color-border);
    border-radius: var(--ym-radius-md);
}

/* ---------- Table ---------- */

.ym-compare__table {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
    font-size: var(--ym-font-size-sm);
}

/* ---------- Rows ---------- */

.ym-compare__row {
    border-bottom: 1px solid var(--ym-color-border);
}

.ym-compare__row:last-child {
    border-bottom: none;
}

.ym-compare__row--header {
    background-color: var(--ym-color-bg-gray);
}

.ym-compare__row--rating {
    background-color: var(--ym-color-primary-light);
}

.ym-compare__row--cta {
    background-color: var(--ym-color-bg-gray);
}

/* ---------- Table Header Cells ---------- */

.ym-compare__th {
    padding: var(--ym-space-4);
    text-align: center;
    vertical-align: middle;
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
}

.ym-compare__th--label {
    text-align: left;
    width: 120px;
    min-width: 120px;
    background-color: var(--ym-color-bg-gray);
    font-size: var(--ym-font-size-xs);
    color: var(--ym-color-text-light);
    font-weight: var(--ym-font-weight-bold);
}

.ym-compare__th--service {
    padding: var(--ym-space-6) var(--ym-space-4);
    text-align: center;
    vertical-align: top;
}

.ym-compare__th-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--ym-space-2);
}

/* ---------- Table Data Cells ---------- */

.ym-compare__td {
    padding: var(--ym-space-3) var(--ym-space-4);
    text-align: center;
    vertical-align: middle;
    color: var(--ym-color-text);
}

.ym-compare__td--label {
    text-align: left;
    width: 120px;
    min-width: 120px;
    background-color: var(--ym-color-bg-gray);
    font-size: var(--ym-font-size-xs);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-text-light);
}

.ym-compare__td--value {
    font-size: var(--ym-font-size-sm);
}

/* ---------- Logo ---------- */

.ym-compare__logo {
    border-radius: var(--ym-radius-md);
    border: 1px solid var(--ym-color-border);
    background-color: var(--ym-color-bg-gray);
    object-fit: contain;
}

.ym-compare__logo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background-color: var(--ym-color-primary);
    color: #fff;
    font-family: var(--ym-font-heading);
    font-weight: var(--ym-font-weight-bold);
    font-size: var(--ym-font-size-lg);
    border-radius: var(--ym-radius-md);
    border: 1px solid var(--ym-color-border);
    flex-shrink: 0;
}

/* ---------- Service Name Link ---------- */

.ym-compare__name {
    font-size: var(--ym-font-size-sm);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
    text-decoration: none;
    transition: color var(--ym-transition-fast);
}

.ym-compare__name:hover {
    color: var(--ym-color-primary);
    text-decoration: underline;
}

/* ---------- Price ---------- */

.ym-compare__price {
    font-size: var(--ym-font-size-lg);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-primary);
}

/* ---------- N/A (要問合せ) ---------- */

.ym-compare__na {
    font-size: var(--ym-font-size-xs);
    color: var(--ym-color-text-light);
}

/* ---------- Review Count ---------- */

.ym-compare__review-count {
    font-size: var(--ym-font-size-xs);
    color: var(--ym-color-text-light);
    margin-left: var(--ym-space-1);
}

/* ==========================================================================
   Radar Chart Comparison (page-compare.php)
   ========================================================================== */

.ym-compare-radar {
    margin-top: var(--ym-space-12);
    padding-top: var(--ym-space-8);
    border-top: 1px solid var(--ym-color-border);
}

.ym-compare-radar__title {
    font-family: var(--ym-font-heading);
    font-size: var(--ym-font-size-xl);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
    text-align: center;
    margin-bottom: var(--ym-space-8);
}

.ym-compare-radar__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ym-space-6);
}

@media (min-width: 768px) {
    .ym-compare-radar__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .ym-compare-radar__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ym-compare-radar__item {
    text-align: center;
    padding: var(--ym-space-4);
    background-color: var(--ym-color-bg);
    border: 1px solid var(--ym-color-border);
    border-radius: var(--ym-radius-md);
}

.ym-compare-radar__name {
    font-size: var(--ym-font-size-base);
    font-weight: var(--ym-font-weight-bold);
    color: var(--ym-color-secondary);
    margin-bottom: var(--ym-space-3);
}

.ym-compare-radar__canvas {
    max-width: 280px;
    max-height: 280px;
    margin: 0 auto;
}
