/*
Theme Name: 三重県商工会青年部連合会
Author: Antigravity
Description: 三重県商工会青年部連合会の公式サイト用テーマ
Version: 1.0.0
Text Domain: mie-prefectural-federation-of-youth-leagues
*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,1,0');

h2 {
    font-size: 2rem;
}

/* Slider Styles */
.is-style-slider .splide__list {
    display: flex !important;
    padding: 0;
    margin: 0;
}

.is-style-slider .splide__slide {
    height: auto;
}

.is-style-slider .splide__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    margin-top: 2rem;
}

.is-style-slider .splide__pagination {
    position: static;
    display: flex;
    gap: 0.5rem;
    padding: 0;
    margin: 0;
}

.is-style-slider .splide__pagination li {
    display: flex;
    align-items: center;
}

.is-style-slider .splide__pagination__page {
    width: 16px;
    height: 16px;
    background: #DDDDDD;
    border-radius: 50%;
    border: none;
    margin: 0;
    padding: 0;
    opacity: 1;
    transition: background 0.2s, transform 0.2s;
}

.is-style-slider .splide__pagination__page.is-active {
    background: #275683;
    transform: none;
}

.is-style-slider .splide__arrow {
    position: static;
    transform: none;
    background: #275683;
    opacity: 0.8;
    width: 24px;
    height: 24px;
}

.is-style-slider .splide__arrow svg {
    fill: #fff;
    width: 12px;
    height: 12px;
}

.is-style-slider .splide__arrow:hover {
    opacity: 1;
}

h3 {
    font-size: 1.5rem;
}

h4 {
    font-size: 1.375rem;
}


/**
 * 見出しスタイル: セクションタイトル
 */
.wp-block-heading.is-style-section-title {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 50px;
    margin-bottom: 40px;
    border: none;
    text-align: center;
    isolation: isolate;
    /* 背面の要素が消えないようにスタック文脈を分離 */
}

.wp-block-heading.is-style-section-title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    background-color: #e1ebf2;
    border-radius: 50%;
    z-index: -1;
    /* isolation: isolate と組み合わせることで親の直後に配置 */
}

.wp-block-heading.is-style-section-title {
    color: #2b5a84;
    /* ネイビー */
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

/* 影ありスタイル */
.wp-block-heading.is-style-section-title-shadow {
    text-shadow: 0 0.1em 0.2em rgba(0, 0, 0, 0.3);
}

/**
 * 段落スタイル: サブタイトル
 */
.wp-block-paragraph.is-style-subtitle {
    display: block;
    margin-top: -30px;
    /* 見出しとの間隔を詰める */
    margin-bottom: 40px;
    color: #c5a059;
    /* 金色 */
    font-family: 'Montserrat', sans-serif;
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: capitalize;
    text-align: center;
}

/* エディタ内での表示調整 */
.edit-post-visual-editor .wp-block-paragraph.is-style-subtitle {
    margin-top: 0;
}

/**
 * 見出しスタイル: セクションタイトル（白）
 */
.wp-block-heading.is-style-section-title-white {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 50px;
    margin-bottom: 40px;
    border: none;
    text-align: center;
    color: #ffffff;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    isolation: isolate;
}

.wp-block-heading.is-style-section-title-white::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    background-color: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    z-index: -1;
}

/**
 * 段落スタイル: サブタイトル（白）
 */
.wp-block-paragraph.is-style-subtitle-white {
    display: block;
    margin-top: -30px;
    /* 見出しとの間隔を詰める */
    margin-bottom: 40px;
    color: #EDC554;
    /* 金色 */
    font-family: 'Montserrat', sans-serif;
    font-size: 1.125rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: capitalize;
    text-align: center;
}

/* エディタ内での表示調整 */
.edit-post-visual-editor .wp-block-paragraph.is-style-subtitle-white {
    margin-top: 0;
}

/**
 * 見出しスタイル: サイドボーダー
 */
.wp-block-heading.is-style-side-border {
    position: relative;
    padding-left: 20px;
}

.wp-block-heading.is-style-side-border::before {
    content: "";
    position: absolute;
    top: 0.1em;
    bottom: 0.1em;
    left: 0;
    width: 4px;
    background-color: #02101D;
    border-radius: 2px;
}

/**
 * 全幅・幅広対応
 */
body {
    overflow-x: hidden;
}

/* 全幅 (alignfull) */
.alignfull {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: none;
}

/* 幅広 (alignwide) */
.alignwide {
    width: 1200px;
    margin-left: calc(50% - 600px);
    margin-right: calc(50% - 600px);
    max-width: 100vw;
}

@media screen and (max-width: 1200px) {
    .alignwide {
        width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
    }
}

/**
 * ユーティリティ: 最大幅を画面幅に制限
 */
.max-w-screen {
    max-width: 100vw !important;
}

/**
 * カラムスタイル: 画面端まで拡張 (Bleed Left/Right)
 * カラムブロックを「全幅」に設定して使用します。
 */
.wp-block-columns.is-style-bleed-right,
.wp-block-columns.is-style-bleed-left {
    max-width: none !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

/* 右側を拡張: 左側にコンテンツ余白、右カラムは余白なし */
.wp-block-columns.is-style-bleed-right>.wp-block-column:first-child {
    padding-left: max(20px, calc((100vw - 1000px) / 2));
    padding-right: 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.wp-block-columns.is-style-bleed-right>.wp-block-column:last-child {
    justify-content: center;
}

.wp-block-columns.is-style-bleed-left>.wp-block-column:first-child {
    padding: 0 !important;
    margin-right: 0 !important;
}

/* 共通: 拡張側の画像やカバーをフィットさせる */
.wp-block-columns.is-style-bleed-right>.wp-block-column:last-child img,
.wp-block-columns.is-style-bleed-right>.wp-block-column:last-child .wp-block-cover,
.wp-block-columns.is-style-bleed-left>.wp-block-column:first-child img,
.wp-block-columns.is-style-bleed-left>.wp-block-column:first-child .wp-block-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: 0;
}

/* スマホ表示での調整 */
@media screen and (max-width: 781px) {

    .wp-block-columns.is-style-bleed-right,
    .wp-block-columns.is-style-bleed-left,
    .wp-block-columns.is-style-reverse-on-mobile {
        flex-direction: column-reverse;
    }

    .wp-block-columns.is-style-bleed-right>.wp-block-column:first-child,
    .wp-block-columns.is-style-bleed-left>.wp-block-column:last-child {
        padding: 40px 20px;
    }
}

/**
 * Variable Definition
 */
:root {
    --wp-admin-bar-height: 0px;
    --site-header-height: 60px;
    --border-line: #D3DCE6;
}

.admin-bar {
    --wp-admin-bar-height: 32px;
}

@media screen and (max-width: 782px) {
    .admin-bar {
        --wp-admin-bar-height: 46px;
    }
}

/**
 * Fixed/Sticky Header の位置調整
 * headerタグまたは.site-headerクラスを強制的に上部に固定します。
 */
header,
.site-header {
    position: fixed !important;
    top: var(--wp-admin-bar-height) !important;
    left: 0 !important;
    width: 100% !important;
    z-index: 99999 !important;
    background-color: #ffffff !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}

/**
 * Main Content の位置調整
 * 手動（スペーサーブロック等）で調整するため、自動パディングは削除しました。
 */
.site-main {
    /* 自動調整なし */
}

/**
 * カバーブロックスタイル: ぼかし
 */
.wp-block-cover.is-style-blur img.wp-block-cover__image-background,
.wp-block-cover.is-style-blur .wp-block-cover__background {
    filter: blur(2px);
    transform: scale(1.02);
    /* 縁の白浮きを防止 */
}

/**
 * カバーブロックスタイル: ヒーロー（丸付き）
 */
.wp-block-cover.is-style-hero-with-circle {
    position: relative;
    overflow: hidden;
}

.wp-block-cover.is-style-hero-with-circle::after {
    content: "";
    position: absolute;
    bottom: -60px;
    right: 10%;
    width: 224px;
    height: 224px;
    background-color: #EDC554;
    border-radius: 50%;
    z-index: 1;
    pointer-events: none;
}

/* PC表示: コンテンツ（1000px）の右端に配置 */
@media screen and (min-width: 1000px) {
    .wp-block-cover.is-style-hero-with-circle::after {
        right: calc(50% - 500px);
    }
}

/* スマホ表示での調整 */
@media screen and (max-width: 782px) {
    .wp-block-cover.is-style-hero-with-circle::after {
        width: 180px;
        height: 180px;
        right: -5%;
        top: 60%;
    }
}

.wp-block-cover.is-style-hero-with-circle .wp-block-cover__inner-container {
    position: relative;
    z-index: 2;
}

/* ヒーロー（丸付き）の背景にぼかしを追加 */
.wp-block-cover.is-style-hero-with-circle img.wp-block-cover__image-background,
.wp-block-cover.is-style-hero-with-circle .wp-block-cover__background {
    filter: blur(2px);
    transform: scale(1.02);
}

/* Breadcrumbs */
.mie-breadcrumbs,
.wp-block-mie-youth-breadcrumbs,
.editor-styles-wrapper .mie-breadcrumbs,
.editor-styles-wrapper .wp-block-mie-youth-breadcrumbs {
    background: #ffffff;
    padding: 12px 0;
}

.mie-breadcrumbs ul,
.wp-block-mie-youth-breadcrumbs ul,
.editor-styles-wrapper .mie-breadcrumbs ul,
.editor-styles-wrapper .wp-block-mie-youth-breadcrumbs ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.mie-breadcrumbs li,
.wp-block-mie-youth-breadcrumbs li,
.editor-styles-wrapper .mie-breadcrumbs li,
.editor-styles-wrapper .wp-block-mie-youth-breadcrumbs li {
    font-size: 14px;
    color: #698AA9;
    display: flex;
    align-items: center;
}

.mie-breadcrumbs a {
    color: #698AA9 !important;
    text-decoration: none;
    transition: color 0.2s;
    display: flex;
    align-items: center;
}

.mie-breadcrumbs a:hover,
.wp-block-mie-youth-breadcrumbs a:hover,
.editor-styles-wrapper .mie-breadcrumbs a:hover,
.editor-styles-wrapper .wp-block-mie-youth-breadcrumbs a:hover {
    color: #275683 !important;
}

.mie-breadcrumbs .material-symbols-outlined,
.wp-block-mie-youth-breadcrumbs .material-symbols-outlined,
.editor-styles-wrapper .mie-breadcrumbs .material-symbols-outlined,
.editor-styles-wrapper .wp-block-mie-youth-breadcrumbs .material-symbols-outlined {
    font-family: 'Material Symbols Outlined' !important;
    font-size: 20px;
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    color: #BDCCD9;
    margin-right: 4px;
    display: inline-block;
}

.mie-breadcrumbs span:not(.material-symbols-outlined) {
    color: #698AA9;
}

/* 区切り線ブロックの追加スタイル: ボーダー (1px) */
.wp-block-separator.is-style-border-1px {
    border-width: 1px !important;
}

/* エディタ内での表示調整 */
.editor-styles-wrapper .wp-block-separator.is-style-border-1px {
    border-width: 1px !important;
}

/**
 * グループブロックスタイル: アーチ型ヘッダー
 */
.wp-block-group.is-style-arch-header {
    position: relative;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-height: 280px;
    padding: 50px 20px 20px;
}

.wp-block-group.is-style-arch-header::before {
    content: "";
    position: absolute;
    bottom: -100px;
    left: 50%;
    transform: translateX(-50%);
    width: 300px;
    height: 300px;
    background-color: #EDC554;
    border-radius: 50%;
    z-index: 1;
}

.wp-block-group.is-style-arch-header>* {
    position: relative;
    z-index: 2;
}


/**
 * カテゴリーブロック: カラーバッジ
 */
.wp-block-categories.is-style-colored-badges,
.wp-block-post-terms.is-style-colored-badges {
    list-style: none !important;
    padding: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.wp-block-categories.is-style-colored-badges li {
    margin: 0 !important;
}

/* Categories List (li a) and Post Terms (a) */
.wp-block-categories.is-style-colored-badges li a,
.wp-block-post-terms.is-style-colored-badges a {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 0;
    color: #ffffff !important;
    text-decoration: none;
    transition: opacity 0.2s;
    background-color: #0066cc;
    /* Fallback */
}

.wp-block-categories.is-style-colored-badges li a:hover,
.wp-block-post-terms.is-style-colored-badges a:hover {
    opacity: 0.8;
}

/**
 * イベント開催日ブロック (Event Date Block)
 */
.event-date-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    line-height: 1.1;
    padding: 10px;
}

/* 黄色の丸 (16px) */
.event-date-dot {
    width: 16px;
    height: 16px;
    background-color: #EDC554;
    border-radius: 50%;
    margin-bottom: 8px;
}

/* 年 (小さいフォント) */
.event-date-year {
    font-size: 0.9rem;
    font-weight: 400;
    margin-bottom: 4px;
    letter-spacing: 0.05em;
}

/* 月日 (大きいフォント) */
.event-date-main {
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

/* エディタ内でのフォント強制適用 */
.editor-styles-wrapper .event-date-block {
    font-family: 'Montserrat', sans-serif;
}

/**
 * リストデフォルトスタイル
 */
.wp-block-list {
    padding-left: 1.5em;
    margin-bottom: 1.5em;
    color: #02101D;
}

ul.wp-block-list {
    list-style-type: disc;
}

ol.wp-block-list {
    list-style-type: decimal;
}

.wp-block-list li {
    margin-bottom: 0.5em;
    line-height: 1.6;
}

.wp-block-list li:last-child {
    margin-bottom: 0;
}

/* ネストされたリストの調整 */
.wp-block-list .wp-block-list {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
}

/**
 * リストスタイル: ダイヤモンドマーカー
 */
.wp-block-list.is-style-diamond-marker {
    list-style-type: none;
    padding-left: 0;
}

/**
 * Contact Form 7 Custom Styles (Robust Version)
 */
.mie-contact-form {
    max-width: 1000px;
    margin: auto;
    padding: 0 20px;
}

.mie-contact-form .form-intro {
    margin-bottom: 40px !important;
    line-height: 1.8;
}

.mie-contact-form .form-item {
    display: flex !important;
    margin-bottom: 25px !important;
    border-bottom: 1px solid #edf2f7 !important;
    padding-bottom: 25px !important;
}

.mie-contact-form .form-label {
    width: 200px !important;
    font-weight: 700 !important;
    color: #02101D !important;
    flex-shrink: 0 !important;
    padding-top: 12px !important;
}

.mie-contact-form .form-content {
    flex-grow: 1 !important;
}

/* 予期せぬ p / br タグの挙動を抑制 */
.mie-contact-form p,
.mie-contact-form br {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}

.mie-contact-form .form-intro p,
.mie-contact-form .form-footer-notes p {
    margin-bottom: 1em !important;
}

.mie-contact-form .form-label p,
.mie-contact-form .form-content p {
    display: block !important;
}

.mie-contact-form .form-item {
    display: flex !important;
    flex-wrap: nowrap !important;
    margin-bottom: 25px !important;
    border-bottom: 1px solid #edf2f7 !important;
    padding-bottom: 25px !important;
}

.mie-contact-form .form-content input[type="text"],
.mie-contact-form .form-content input[type="email"],
.mie-contact-form .form-content input[type="tel"],
.mie-contact-form .form-content textarea {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 1px solid #CBD5E0 !important;
    border-radius: 4px !important;
    font-size: 16px !important;
    background-color: #fff !important;
    box-sizing: border-box !important;
    display: block !important;
}

.mie-contact-form .form-content input:focus,
.mie-contact-form .form-content textarea:focus {
    outline: none !important;
    border-color: #275683 !important;
    box-shadow: 0 0 0 3px rgba(39, 86, 131, 0.1) !important;
}

.mie-contact-form .form-content textarea {
    height: 300px !important;
}

.mie-contact-form {
    max-width: 1000px;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 20px;
}

.mie-contact-form .form-submit,
.mie-contact-form .form-submit p {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    width: 100% !important;
}

.mie-contact-form .form-submit {
    padding: 40px 0 !important;
}

.mie-contact-form .wpcf7-submit {
    display: inline-block !important;
    background-color: #275683 !important;
    color: #fff !important;
    border: none !important;
    padding: 16px 80px !important;
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    box-shadow: 0 4px 12px rgba(39, 86, 131, 0.2) !important;
    margin: 0 auto !important;
}

.mie-contact-form .form-footer-notes {
    background-color: #F7FAFC !important;
    padding: 35px !important;
    border-radius: 8px !important;
    font-size: 0.9rem !important;
    color: #4A5568 !important;
    line-height: 1.8 !important;
}

/* モバイル対応 */
@media screen and (max-width: 767px) {
    .mie-contact-form .form-item {
        flex-direction: column !important;
    }

    .mie-contact-form .form-label {
        width: 100% !important;
        padding-top: 0 !important;
        margin-bottom: 12px !important;
    }
}

/**
 * 画像ブロックスタイル: 円形キャプション
 */
.wp-block-image.is-style-caption-circle {
    position: relative;
    /* 下側に突き抜けるため適切なマージンを確保 */
    margin-bottom: 96px;
}

.wp-block-image.is-style-caption-circle figcaption {
    position: absolute;
    bottom: -80px;
    right: 0;
    left: 0;
    margin: auto;
    width: 120px;
    aspect-ratio: 1/1;
    background-color: #EDC554;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #275683;
    box-sizing: border-box;
    z-index: 10;
}

/* エディタ内での表示調整（絶対配置の影響を抑える） */
.editor-styles-wrapper .wp-block-image.is-style-caption-circle {
    overflow: visible;
}

.wp-block-list.is-style-diamond-marker li {
    position: relative;
    padding-left: 35px;
}

.wp-block-list.is-style-diamond-marker li::before {
    content: "";
    position: absolute;
    left: 0.5em;
    top: 0.5em;
    width: 1em;
    height: 1em;
    background-color: #dbe7f0;
    transform: rotate(45deg);
}

/* エディタ内での調整 */
.editor-styles-wrapper .wp-block-list.is-style-diamond-marker {
    list-style-type: none;
    padding-left: 0;
}