/*
 Theme Name:   Swell Child - 不動産サイト
 Theme URI:    https://github.com/hiro-osh/wp-realestate-starter
 Description:  Swell子テーマ - 不動産会社向けカスタマイズ
 Author:       hiroyoshi
 Template:     swell
 Version:      1.0.0
 Text Domain:  swell-child
*/

/* ============================================================
   デザインシステム — カラーパレット & タイポグラフィ
   Coastal Teal + Sand Gold — 沖縄の海と砂を想起させる配色
   ============================================================ */
:root {
    --re-primary:  #1a5c5c;
    --re-accent:   #c9a96e;
    --re-dark:     #1a1a2e;
    --re-text:     #2d2d2d;
    --re-muted:    #6b7280;
    --re-light-bg: #f7f6f3;
    --re-white:    #ffffff;
    --re-border:   #e5e2dc;
}

/* --- タイポグラフィ --- */
body {
    font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
    color: var(--re-text);
}
h1, h2, h3, h4, h5, h6,
.wp-block-heading {
    font-family: 'Noto Serif JP', 'Yu Mincho', serif;
}

/* --- ヘッダー サイト名フォント --- */
.c-headLogo__text,
.c-headLogo a,
.l-header__logo a {
    font-family: 'Montserrat', 'Inter', sans-serif !important;
    font-weight: 600;
    letter-spacing: 0.08em;
    font-size: 1.4em;
}

/* --- プラン説明文（h1下） --- */
.plan-description {
    text-align: center;
    font-size: 14px;
    color: var(--re-muted);
    margin: 8px 0 32px;
    font-weight: 400;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

/* ============================================================
   レイアウト — サイドバー非表示・フルワイド化
   ============================================================ */
#sidebar,
.l-sidebar,
.c-sidebar,
.widget-area,
aside.sidebar {
    display: none !important;
}

#content,
.l-content,
.l-mainContent,
.c-mainContent,
.l-main,
.swell-main-content {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 auto !important;
    float: none !important;
}

body .l-content {
    display: block !important;
}
body .l-mainContent {
    flex: 1 1 100% !important;
    max-width: 100% !important;
}

/* --- ブログ系ウィジェット非表示 --- */
.widget_recent_entries,
.widget_recent_comments,
.widget_archive,
.widget_categories,
.widget_meta,
.widget_tag_cloud,
.widget_calendar {
    display: none !important;
}

/* --- 物件一覧・詳細ページの幅調整 --- */
.post-type-archive-property .l-mainContent__inner,
.single-property .l-mainContent__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
}

/* --- トップページ（Light / Standard 共通）のフルワイド化 --- */
.page-template-default .l-mainContent__inner,
.page-template .l-mainContent__inner {
    max-width: 100%;
    padding: 0;
}

/* ============================================================
   共通コンポーネント
   ============================================================ */

/* --- ページネーション --- */
.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 4px 12px;
    border-radius: 6px;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    color: var(--re-text);
    background: var(--re-light-bg);
    border: 1px solid var(--re-border);
    transition: background-color 0.2s ease, color 0.2s ease;
}
.page-numbers:hover {
    background: var(--re-border);
    color: var(--re-dark);
}
.page-numbers.current {
    background: var(--re-primary);
    color: var(--re-white);
    border-color: var(--re-primary);
}

/* --- 物件カード共通 --- */
.property-card {
    cursor: pointer;
}

/* ============================================================
   ブロックエディタ系スタイル（Light / Standard 共通）
   ============================================================ */

/* --- ボタン角丸・フォント統一 --- */
.wp-block-button__link {
    border-radius: 6px;
    font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
    font-weight: 600;
    transition: opacity 0.2s ease, transform 0.2s ease;
}
.wp-block-button__link:hover {
    opacity: 0.9;
}

/* --- Cover ブロック見出し --- */
.wp-block-cover h1,
.wp-block-cover h2 {
    font-family: 'Noto Serif JP', 'Yu Mincho', serif;
    text-shadow: 0 2px 16px rgba(0,0,0,0.25);
}

/* --- テーブルブロック改善 --- */
.wp-block-table table {
    border-collapse: collapse;
    width: 100%;
}
.wp-block-table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--re-border);
    font-size: 14px;
    line-height: 1.7;
}
.wp-block-table td:first-child {
    color: var(--re-primary);
    font-weight: 500;
    background: var(--re-light-bg);
    width: 160px;
}
@media (max-width: 768px) {
    .wp-block-table td:first-child {
        width: 120px;
    }
}

/* --- セパレーター --- */
.wp-block-separator.is-style-wide {
    border-color: var(--re-border);
    max-width: 60px;
    margin-left: auto;
    margin-right: auto;
}

/* --- Columns ブロックのカード風カラム --- */
.wp-block-column[style*="background-color:#f7f6f3"] {
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.wp-block-column[style*="background-color:#f7f6f3"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

/* ============================================================
   Standard プラン限定 — 要所カスタム
   .page-id-XX ではなく slug ベースで判定。Standard ページの
   ブロックコンテンツに追加クラスを付けられないため、
   共通 style.css で差分を吸収する。
   ============================================================ */

/* --- Standard: Media & Text — 代表挨拶の画像に装飾 --- */
.wp-block-media-text__media img {
    border-radius: 12px;
    transition: transform 0.4s ease;
}
.wp-block-media-text:hover .wp-block-media-text__media img {
    transform: scale(1.02);
}

/* --- Standard: サービスカラム（border付き）のホバー --- */
.wp-block-column[style*="border-color:#e5e2dc"] {
    transition: border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
    cursor: pointer;
}
.wp-block-column[style*="border-color:#e5e2dc"]:hover {
    border-color: var(--re-primary) !important;
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

/* --- Standard/Light: CTA セクションのボタン — ホバー強化 --- */
.wp-block-group[style*="background-color:#1a5c5c"] .wp-block-button__link {
    transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease;
}
.wp-block-group[style*="background-color:#1a5c5c"] .wp-block-button__link:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.2);
    opacity: 1;
}

/* --- Standard: 理由カラムの上部アクセントライン --- */
.wp-block-column[style*="background-color:#f7f6f3"] {
    position: relative;
    overflow: hidden;
}
.wp-block-column[style*="background-color:#f7f6f3"]::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--re-primary), #2ba5a5);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.35s ease;
}
.wp-block-column[style*="background-color:#f7f6f3"]:hover::before {
    transform: scaleX(1);
}

/* --- Standard: Cover ヒーローのオーバーレイにグラデーション方向感 --- */
.wp-block-cover.alignfull .wp-block-cover__background {
    background: linear-gradient(160deg, rgba(0,0,0,0.6) 0%, rgba(26,92,92,0.4) 100%) !important;
}

/* --- Standard: おすすめ物件セクションの背景ボーダー装飾 --- */
.wp-block-group[style*="background-color:#f7f6f3"] {
    position: relative;
}
.wp-block-group[style*="background-color:#f7f6f3"]::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--re-primary), var(--re-accent), var(--re-primary));
    background-size: 200% 100%;
}

/* --- Standard: Media & Text の左側にアクセントライン --- */
.wp-block-media-text {
    position: relative;
}
.wp-block-media-text::before {
    content: '';
    position: absolute;
    top: 10%;
    bottom: 10%;
    left: 0;
    width: 3px;
    background: linear-gradient(to bottom, var(--re-primary), var(--re-accent));
    border-radius: 2px;
}

/* --- Standard: 絵文字アイコン行のサイズ補正 --- */
.wp-block-column p[style*="font-size:36px"],
.wp-block-column p[style*="font-size:32px"] {
    line-height: 1;
    margin-bottom: 8px;
}

/* ============================================================
   スマホ表示修正（Light / Standard 共通）
   ============================================================ */
@media (max-width: 599px) {
    /* Cover ヒーローの見出し */
    .wp-block-cover h1 {
        font-size: 28px !important;
        line-height: 1.4;
    }
    /* Cover ヒーローのボタン */
    .wp-block-cover .wp-block-buttons {
        flex-direction: column;
        align-items: center;
    }
    .wp-block-cover .wp-block-button {
        width: 80%;
    }
    /* Media & Text がスタックした時の画像 */
    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
        max-width: 280px;
        margin: 0 auto;
    }
    /* テーブルの横スクロール防止 */
    .wp-block-table td:first-child {
        width: 100px !important;
        font-size: 12px;
    }
    .wp-block-table td {
        font-size: 13px;
        padding: 10px 8px;
    }
    /* エリア画像カラム：2列に */
    .wp-block-columns:has(> .wp-block-column > .wp-block-image) {
        flex-wrap: wrap !important;
    }
    /* CTA ボタン */
    .wp-block-group[style*="background-color:#1a5c5c"] .wp-block-button {
        width: 100%;
    }
}

/* --- prefers-reduced-motion --- */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
