/* OpenClaw TASK-20260501-003 Gate A: homepage split handle marker. */
:root{--shinra-split-home:1;}

/* === OpenClaw Gate B5a: homepage hero CSS migrated from shinra-custom.css === */
/* ══ HOMEPAGE HERO ═══════════════════════════════════════ */
.shinra-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 480px;
}
.shinra-hero-left {
    background: linear-gradient(135deg, #6F7C65 0%, #6F7C65 100%);
    padding: 64px 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.shinra-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 10px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #6F7C65;
    margin-bottom: 22px;
}
.shinra-hero-eyebrow::before {
    content: '';
    display: block;
    width: 24px; height: 1px;
    background: #973226;
}
.shinra-hero h1 {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 38px !important;
    line-height: 1.45 !important;
    color: #FAFAF8 !important;
    margin-bottom: 18px !important;
    letter-spacing: 1.5px !important;
}
.shinra-hero h1 strong {
    color: #DACDB8;
}
.shinra-hero-desc {
    font-size: 13.5px;
    line-height: 1.9;
    color: rgba(245,239,230,0.65);
    max-width: 380px;
    margin-bottom: 32px;
}
.shinra-hero-btns {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.shinra-btn-primary {
    display: inline-block;
    background: #973226;
    color: white !important;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 13px 28px;
    text-decoration: none !important;
    transition: background .2s;
}
.shinra-btn-primary:hover { background: #973226 !important; }
.shinra-btn-ghost {
    display: inline-block;
    border: 1px solid rgba(245,239,230,0.4);
    color: rgba(245,239,230,0.8) !important;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 12px 22px;
    text-decoration: none !important;
    transition: border-color .2s;
}
.shinra-btn-ghost:hover {
    border-color: rgba(245,239,230,0.8) !important;
    color: #FAFAF8 !important;
}
.shinra-hero-right {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 3px;
    background: #DACDB8;
    overflow: hidden;
}
.shinra-hero-img {
    background: #DACDB8;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
}
.shinra-hero-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.shinra-hero-img:first-child {
    grid-column: 1 / 3;
}
.shinra-hero-img-label {
    position: absolute;
    bottom: 10px; left: 12px;
    font-family: var(--shinra-sans, 'Hiragino Kaku Gothic ProN', 'Yu Gothic', 'Meiryo', system-ui, sans-serif);
    font-size: 13px;
    font-weight: 600;
    color: white;
    background: rgba(74,99,87,0.88);
    padding: 4px 10px;
}


/* ── Hero 右側三圖尺寸 1000x750 ── */
.shinra-hero-right {
    height: 750px;
    overflow: hidden;
}
.shinra-hero-img {
    overflow: hidden;
    position: relative;
    display: block;
}
.shinra-hero-img--main {
    height: 500px !important;
    min-height: unset !important;
}
.shinra-hero-img:not(.shinra-hero-img--main) {
    height: 250px !important;
    min-height: unset !important;
}
.shinra-hero-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ── Hero 標題字級 -4px ── */
.shinra-hero-left h1 {
    font-size: calc(var(--blocksy-heading-h1-font-size, 3rem) - 4px) !important;
}

/* ── 手機版 Hero 標題再 -4px ── */
@media (max-width: 768px) {
    .shinra-hero-left h1 {
        font-size: calc(var(--blocksy-heading-h1-font-size, 3rem) - 12px) !important;
    }
}


/* ── Hero 高度縮為一半 ── */
.shinra-hero {
    min-height: 240px !important;
}
.shinra-hero-right {
    height: 375px !important;
}
.shinra-hero-img--main {
    height: 250px !important;
}
.shinra-hero-img:not(.shinra-hero-img--main) {
    height: 125px !important;
}
@media (max-width: 768px) {
    .shinra-hero {
        min-height: 200px !important;
        padding: 28px 20px !important;
    }
}

/* ── Hero 右側改為 3 欄橫排 ── */
.shinra-hero-right {
    grid-template-columns: repeat(3, 1fr) !important;
    grid-template-rows: 1fr !important;
    height: 240px !important;
}
.shinra-hero-img--main {
    grid-column: auto !important;
    height: 240px !important;
}
.shinra-hero-img:not(.shinra-hero-img--main) {
    height: 240px !important;
}

/* ── Hero left padding 縮短配合新高度 ── */
.shinra-hero-left {
    padding: 28px 56px !important;
}

/* ── Hero 右側高度跟隨左側（grid 自動對齊）── */
.shinra-hero-right {
    height: auto !important;
    align-self: stretch !important;
}
.shinra-hero-img,
.shinra-hero-img--main,
.shinra-hero-img:not(.shinra-hero-img--main) {
    height: 100% !important;
    min-height: 0 !important;
}


/* ── 手機版 Hero 簡化版（只留標題+按鈕）── */
@media (max-width: 768px) {
    .shinra-hero-left {
        padding: 20px 24px !important;
    }
    .shinra-hero-eyebrow {
        display: none !important;
    }
    .shinra-hero-desc {
        display: none !important;
    }
    .shinra-hero h1 {
        margin-bottom: 14px !important;
    }
}

/* ── 手機版 Hero 上方留白移除 ── */
@media (max-width: 768px) {
    .page-id-127 .entry-content,
    .page-id-127 .entry-content &gt; *:first-child,
    .page-id-127 .wp-block-html:first-child {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    .page-id-127 .hero-section {
        display: none !important;
        height: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
    }
}


/* 2026-04-26: Mobile homepage removes Hero block; desktop keeps mosaic. */
@media (max-width: 560px) {
    .page-id-127 .shinra-home-hero {
        display: none !important;
    }
    .page-id-127 .shinra-section--latest-magazine {
        margin-top: 34px;
    }
}


/* 2026-04-26: Hide desktop Hero brand text above mosaic. */
.page-id-127 .shinra-home-brand {
    display: none !important;
}
.page-id-127 .shinra-home-hero {
    margin-top: 34px;
}


/* 2026-04-26: Temporarily hide homepage Hero on all devices. */
.page-id-127 .shinra-home-hero {
    display: none !important;
}
.page-id-127 .shinra-section--latest-magazine:first-of-type,
.page-id-127 .entry-content > .wp-block-html:first-child + .wp-block-html .shinra-section--latest-magazine {
    margin-top: 34px !important;
}


/* === END OpenClaw Gate B5a homepage hero CSS === */

/* === OpenClaw Gate B5b: homepage cards/section CSS migrated from shinra-custom.css === */
/* ══ SECTION HEADER ROW ══════════════════════════════════ */
.shinra-section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding-bottom: 16px;
    margin-bottom: 32px;
}
.shinra-section-more {
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #9A9088;
    text-decoration: none !important;
    display: flex;
    align-items: center;
    gap: 6px;
}
.shinra-section-more:hover { color: #973226 !important; }

/* ══ RECIPE CARD GRID ════════════════════════════════════ */
.shinra-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
    margin-bottom: 16px;
}
.shinra-card {
    background: #FAFAF8;
    border: 1px solid #DACDB8;
    overflow: hidden;
    transition: box-shadow .25s, transform .25s;
    text-decoration: none !important;
    color: #22201D !important;
    display: block;
}
.shinra-card:hover {
    box-shadow: 0 6px 24px rgba(46,40,32,0.1);
    transform: translateY(-3px);
}
.shinra-card-img {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    position: relative;
    background: #DACDB8;
}
.shinra-card-img img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s;
}
.shinra-card:hover .shinra-card-img img { transform: scale(1.04); }
.shinra-card-cat {
    position: absolute;
    top: 10px; left: 10px;
    font-size: 10px;
    letter-spacing: 1px;
    padding: 3px 9px;
    font-weight: 500;
    color: white;
}
.cat-meat  { background: #6F7C65; }
.cat-sea   { background: #3D6080; }
.cat-veg   { background: #6F7C65; }
.shinra-card-body { padding: 16px 18px 20px; }
.shinra-card-time {
    display: inline-block;
    font-size: 10px;
    padding: 2px 8px;
    border: 1px solid #DACDB8;
    color: #22201D;
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}
.shinra-card-title {
    font-family: 'Noto Serif TC', serif;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.4;
    color: #22201D;
    margin-bottom: 10px;
}
.shinra-card-meta {
    display: flex;
    gap: 12px;
    font-size: 11px;
    color: #9A9088;
    border-top: 1px dashed #DACDB8;
    padding-top: 10px;
}

/* ══ ARTICLE CARD GRID ═══════════════════════════════════ */
.shinra-articles {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
}
.shinra-article-card {
    background: #FAFAF8;
    border: 0;
    overflow: hidden;
    transition: box-shadow .25s;
    text-decoration: none !important;
    color: #22201D !important;
    display: flex;
    flex-direction: column;
}
.shinra-article-card:hover { box-shadow: 0 6px 24px rgba(46,40,32,0.1); }
.shinra-article-img {
    width: 100%;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #DACDB8;
}
.shinra-article-img img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .4s;
}
.shinra-article-card:hover .shinra-article-img img { transform: scale(1.04); }
.shinra-article-body {
    padding: 16px 18px 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.shinra-article-tag {
    display: inline-block;
    font-size: 10px;
    padding: 2px 8px;
    background: #DACDB8;
    color: #973226;
    border: 1px solid #DACDB8;
    margin-bottom: 6px;
    letter-spacing: 0.5px;
}
.shinra-article-date {
    font-size: 10px;
    letter-spacing: 1.5px;
    color: #9A9088;
    margin-bottom: 8px;
    text-transform: uppercase;
}
.shinra-article-title {
    font-family: 'Noto Serif TC', serif;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.5;
    color: #22201D;
    margin-bottom: 10px;
    flex: 1;
}
.shinra-article-excerpt {
    font-size: 12.5px;
    color: #22201D;
    line-height: 1.75;
    border-top: 1px dashed #DACDB8;
    padding-top: 10px;
}


/* ── 食譜卡片一行格式 ── */
.shinra-card-body { padding: 12px 16px 14px; }
.shinra-card-oneline {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0;
    font-size: 13px;
    line-height: 1.5;
    color: #22201D;
}
.shinra-card-oneline-title {
    font-family: Noto Serif TC, serif;
    font-weight: 600;
    font-size: 14px;
    color: #22201D;
    flex-shrink: 0;
}
.shinra-card-sep {
    color: #DACDB8;
    padding: 0 6px;
    font-weight: 300;
    flex-shrink: 0;
}
.shinra-card-oneline-cat {
    font-size: 12px;
    color: #6F7C65;
    flex-shrink: 0;
}
.shinra-card-oneline-time {
    font-size: 12px;
    color: #9A9088;
    flex-shrink: 0;
}


/* ── 文章卡片分類標籤移至圖片左上角 ── */
.shinra-article-img { position: relative; overflow: hidden; }
.shinra-article-tag {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 2;
    background: rgba(74, 99, 87, 0.88);
    color: #FAFAF8;
    font-size: 0.65rem;
    letter-spacing: 1px;
    padding: 3px 8px;
    border-radius: 2px;
    font-family: var(--theme-font-family, sans-serif);
}

/* ── Section header 標題與查看全部同行對齊 ── */
.shinra-section-header {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
}
.shinra-section-header &gt; div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}


/* openclaw-card-title-size-15-20260427 */
.page-id-127 .shinra-articles--magazine .shinra-article-title,
.page-id-127 .shinra-article-title {
    font-size: 15px !important;
}
@media (max-width: 560px) {
    .page-id-127 .shinra-articles--magazine .shinra-article-title,
    .page-id-127 .shinra-article-title {
        font-size: 15px !important;
    }
}



/* === END OpenClaw Gate B5b homepage cards/section CSS === */

/* === OpenClaw Gate B5c: homepage finder/about/image CSS migrated from shinra-custom.css === */
/* ══ FEATURE FINDER ══════════════════════════════════════ */
.shinra-finder {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 340px;
}
.shinra-finder-img {
    background: #6F7C65;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}
.shinra-finder-img img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: 0.6;
}
.shinra-finder-img-label {
    position: relative;
    z-index: 2;
    padding: 24px 32px;
    width: 100%;
    background: linear-gradient(to top, rgba(44,60,52,0.88), transparent);
    font-family: 'Noto Serif TC', serif;
    font-size: 22px;
    font-weight: 600;
    color: white;
}
.shinra-finder-content {
    background: #DACDB8;
    padding: 48px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.shinra-finder-content h3 {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 24px !important;
    line-height: 1.5 !important;
    color: #22201D !important;
    margin-bottom: 12px !important;
}
.shinra-finder-content p {
    font-size: 13.5px;
    color: #22201D;
    line-height: 1.9;
    margin-bottom: 24px;
}
.shinra-filter-group { margin-bottom: 14px; }
.shinra-filter-label {
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #9A9088;
    margin-bottom: 8px;
    display: block;
}
.shinra-filter-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.shinra-ftag {
    font-size: 11px;
    padding: 6px 14px;
    border: 1px solid #DACDB8;
    color: #22201D;
    background: #FAFAF8;
    text-decoration: none !important;
    transition: .15s;
    display: inline-block;
}
.shinra-ftag:hover {
    background: #6F7C65;
    border-color: #6F7C65;
    color: white !important;
}

/* ══ ABOUT STRIP ═════════════════════════════════════════ */
.shinra-about {
    display: grid;
    grid-template-columns: 280px 1fr;
    background: #6F7C65;
    min-height: 200px;
    overflow: hidden;
}
.shinra-about-photo {
    overflow: hidden;
    position: relative;
}
.shinra-about-photo img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}
.shinra-about-photo-placeholder {
    width: 100%; height: 100%; min-height: 200px;
    background: #6F7C65;
    display: flex; align-items: center; justify-content: center;
    font-size: 48px; color: rgba(255,255,255,0.3);
}
.shinra-about-text {
    padding: 40px 52px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.shinra-about-text h4 {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 20px !important;
    color: #FAFAF8 !important;
    margin-bottom: 12px !important;
}
.shinra-about-text p {
    font-size: 13.5px;
    color: rgba(245,239,230,0.75);
    line-height: 1.9;
    margin-bottom: 20px;
}
.shinra-about-link {
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #973226 !important;
    text-decoration: none !important;
    border-bottom: 1px solid #973226;
    padding-bottom: 2px;
    display: inline-block;
    width: fit-content;
}
.shinra-about-link:hover { color: #FAFAF8 !important; border-color: #FAFAF8 !important; }


/* 2026-04-27: force natural image rendering on home/category pages; no muted/grey treatment. */
.page-id-127 .shinra-article-img,
.page-id-127 .shinra-home-mosaic-item,
.page-id-127 .shinra-home-about-photo {
    background: transparent !important;
}

.page-id-127 .shinra-article-img img,
.page-id-127 .shinra-home-mosaic-item img,
.page-id-127 .shinra-home-about-photo img {
    filter: none !important;
    opacity: 1 !important;
    mix-blend-mode: normal !important;
    -webkit-filter: none !important;
}

.page-id-127 .shinra-finder-img::before,
.page-id-127 .shinra-finder-img::after {
    display: none !important;
    content: none !important;
}


/* 2026-04-27: no transparency on home/category image presentation. */
.page-id-127 .shinra-article-img img,
.page-id-127 .shinra-home-mosaic-item img,
.page-id-127 .shinra-home-about-photo img,
.page-id-127 .shinra-finder-img img {
    opacity: 1 !important;
    filter: none !important;
    -webkit-filter: none !important;
    mix-blend-mode: normal !important;
}

.page-id-127 .shinra-finder-img,
.page-id-127 .shinra-article-img,
.page-id-127 .shinra-home-mosaic-item,
.page-id-127 .shinra-home-about-photo {
    background-color: transparent !important;
    background-blend-mode: normal !important;
}

.page-id-127 .shinra-home-mosaic-text {
    background: var(--shinra-matcha) !important;
}

.page-id-127 .shinra-finder--home-magazine .shinra-finder-img-label,
.page-id-127 .shinra-finder-img-label {
    background: var(--shinra-ink) !important;
    color: var(--shinra-washi) !important;
}

.page-id-127 .shinra-finder-img > div:first-child {
    display: none !important;
    opacity: 1 !important;
    background: none !important;
}



/* 2026-04-29 OpenClaw: align Recipe Finder image label with homepage section titles. */
.page-id-127 .shinra-finder--home-magazine .shinra-finder-img-label,
.page-id-127 .shinra-finder-img-label {
    font-family: var(--shinra-serif) !important;
    font-size: 19px !important;
    font-weight: 600 !important;
    line-height: 1.5 !important;
    letter-spacing: 4px !important;
}


/* 2026-04-29 OpenClaw: force Recipe Finder label to the exact same font stack as section titles. */
.page-id-127 .shinra-finder--home-magazine .shinra-finder-img-label,
.page-id-127 .shinra-finder-img-label {
    font-family: var(--shinra-sans, 'Hiragino Kaku Gothic ProN', 'Yu Gothic', 'Meiryo', system-ui, sans-serif) !important;
}
/* === END OpenClaw Gate B5c homepage finder/about/image CSS === */

/* === OpenClaw Gate B5d: homepage magazine/mobile CSS migrated from shinra-custom.css === */
/* ── 首頁全寬 ── */
.page-id-127 .entry-content { max-width: none !important; width: 100% !important; }
.page-id-127 .entry-content &gt; * { max-width: none !important; }
.page-id-127 .entry-content .wp-block-html { margin: 0 !important; padding: 0 !important; }
.page-id-127 .ct-container-full, .page-id-127 [data-content] { --container-padding: 0 !important; max-width: none !important; }
.page-id-127 article.post { padding: 0 !important; }
.page-id-127 .entry-content .is-layout-flow &gt; * { max-width: 100% !important; }
/* 隱藏首頁的 Blocksy page header */
.page-id-127 .hero-section { display: none !important; }

/* ── 手機兩欄強制覆蓋 ── */
@media (max-width: 768px) {
    .page-id-127 .shinra-cards,
    .shinra-cards,
    .page-id-127 .shinra-articles,
    .shinra-articles {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    .shinra-card,
    .shinra-article-card {
        display: flex !important;
        flex-direction: column !important;
    }
}

/* ── 手機版 section padding 縮小 ── */
@media (max-width: 768px) {
    .page-id-127 section[style] {
        padding-left: 16px !important;
        padding-right: 16px !important;
        padding-top: 36px !important;
        padding-bottom: 36px !important;
    }
    .shinra-section-header { margin-bottom: 20px !important; }
    .shinra-finder-content { padding: 28px 24px !important; }
    .shinra-about-text { padding: 24px 28px !important; }
}

/* ── shinra-section base ── */
.shinra-section {
    padding: 56px 60px;
}
.shinra-section--cream  { background: #FAFAF8; }
.shinra-section--cream2 { background: #DACDB8; }
@media (max-width: 768px) {
    .shinra-section {
        padding: 32px 25px !important;
    }
}

/* ── 移除 section header 分隔線 ── */
.shinra-section-header { border-bottom: none !important; }

/* ── 茄芷袋條紋 wrap（上下留白，與區塊分離）── */
.shinra-stripe-wrap {
    background: #FAFAF8;
    padding: 20px 0;
    width: 100%;
    display: block;
}
.shinra-stripe {
    margin: 0 !important;
}

/* ── 茄芷袋與 section header 間距減半 ── */
.shinra-stripe-wrap {
    padding: 10px 0 !important;
}
.shinra-section {
    padding-top: 28px !important;
    padding-bottom: 28px !important;
}
@media (max-width: 768px) {
    .shinra-section {
        padding-top: 16px !important;
        padding-bottom: 16px !important;
    }
}

/* ── section header 與卡片間距減半 ── */
.shinra-section-header {
    padding-bottom: 8px !important;
    margin-bottom: 16px !important;
}

/* ── 版權宣告 8px ── */
.ct-copyright,
.ct-copyright *,
footer .ct-copyright,
.footer-copyright {
    font-size: 6px !important;
}


/* ═══════════════════════════════════════════════════════════════
   Homepage Magazine Layout v20260426
   Palette: washi white / 和紙白 #FAFAF8 / hinoki #DACDB8 / ink #22201D /
            matcha #6F7C65 / seal #973226
   Scope: page ID 127 only. Does not target single/archive templates.
   ═══════════════════════════════════════════════════════════════ */
.page-id-127 {
    --shinra-washi: #FAFAF8;
    --shinra-ink: #22201D;
    --shinra-hinoki: #DACDB8;
    --shinra-seal: #973226;
    --shinra-matcha: #6F7C65;
    --shinra-hinoki-soft: rgba(218, 205, 184, .42);
    --shinra-matcha-soft: rgba(111, 124, 101, .78);
    background: var(--shinra-washi) !important;
}
.page-id-127 .site-main,
.page-id-127 .entry-content {
    background: var(--shinra-washi) !important;
}
.page-id-127 .entry-content > .wp-block-html {
    margin: 0 !important;
}
.page-id-127 .shinra-home-hero {
    max-width: 1200px;
    margin: 52px auto 0;
    padding: 0;
}
.page-id-127 .shinra-home-brand {
    text-align: center;
    margin-bottom: 42px;
    color: var(--shinra-ink);
}
.page-id-127 .shinra-home-brand-title {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: 7px;
    line-height: 1.6;
    color: var(--shinra-ink);
}
.page-id-127 .shinra-home-brand-title span {
    color: var(--shinra-seal);
    font-size: 10px;
    margin-left: 2px;
    vertical-align: middle;
}
.page-id-127 .shinra-home-brand-subtitle {
    margin-top: 2px;
    font-family: 'Noto Serif TC', serif !important;
    font-size: 12px;
    letter-spacing: 4px;
    color: var(--shinra-matcha);
}
.page-id-127 .shinra-home-mosaic {
    display: grid;
    grid-template-columns: repeat(5, 240px);
    grid-template-rows: repeat(3, 126px);
    width: 1200px;
    max-width: 100%;
    height: 378px;
    gap: 3px;
    background: var(--shinra-hinoki);
}
.page-id-127 .shinra-home-mosaic-item,
.page-id-127 .shinra-home-mosaic-text {
    display: block;
    position: relative;
    overflow: hidden;
    background: var(--shinra-hinoki);
}
.page-id-127 .shinra-home-mosaic-item img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    background: var(--shinra-washi);
    filter: none;
    transition: transform .45s ease, filter .45s ease;
}
.page-id-127 .shinra-home-mosaic-item:hover img {
    transform: scale(1.015);
    filter: none;
}
.page-id-127 .shinra-home-mosaic-text {
    grid-column: auto;
    grid-row: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: var(--shinra-washi);
    background: linear-gradient(rgba(111,124,101,.70), rgba(111,124,101,.70)), var(--shinra-hinoki);
    font-family: 'Noto Serif TC', serif !important;
    letter-spacing: 3px;
}
.page-id-127 .shinra-home-mosaic-text span {
    font-size: 17px;
    font-weight: 600;
    line-height: 1.7;
}
.page-id-127 .shinra-home-mosaic-text small {
    font-size: 12px;
    line-height: 1.8;
    opacity: .92;
}
.page-id-127 .shinra-home-mosaic-item--15,
.page-id-127 .shinra-home-mosaic-item--16,
.page-id-127 .shinra-home-mosaic-item--17,
.page-id-127 .shinra-home-mosaic-item--18 {
    display: none;
}
.page-id-127 .shinra-section--latest-magazine {
    max-width: 1080px;
    margin: 76px auto 0;
    padding: 0 24px;
    background: transparent !important;
}
.page-id-127 .shinra-home-section-head {
    margin-bottom: 28px;
}
.page-id-127 .shinra-home-section-head h2 {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 19px !important;
    font-weight: 600 !important;
    letter-spacing: 4px;
    color: var(--shinra-ink) !important;
    margin: 0 !important;
}
.page-id-127 .shinra-articles--magazine {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 34px 38px !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-card {
    display: block !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    color: var(--shinra-ink) !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-card:hover {
    box-shadow: none !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-img {
    aspect-ratio: 4 / 3;
    background: var(--shinra-hinoki);
    overflow: hidden;
}
.page-id-127 .shinra-articles--magazine .shinra-article-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: none;
    transition: transform .4s ease;
}
.page-id-127 .shinra-articles--magazine .shinra-article-card:hover img {
    transform: scale(1.025);
}
.page-id-127 .shinra-articles--magazine .shinra-article-body {
    padding: 11px 0 0 !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-title {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 15px !important;
    font-weight: 600;
    line-height: 1.65;
    letter-spacing: .6px;
    color: var(--shinra-ink);
    margin: 0 0 4px !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-date {
    font-size: 11px;
    letter-spacing: .8px;
    color: var(--shinra-matcha);
    margin: 0;
}
.page-id-127 .shinra-article-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--shinra-sans, 'Hiragino Kaku Gothic ProN', 'Yu Gothic', 'Meiryo', system-ui, sans-serif);
    font-size: 12px;
    letter-spacing: 2px;
    color: var(--shinra-matcha);
    background: var(--shinra-hinoki-soft);
}
.page-id-127 .shinra-finder--home-magazine {
    max-width: 1080px;
    margin: 86px auto 0;
    grid-template-columns: 1fr 1fr;
    min-height: 330px;
    background: transparent;
}
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content {
    background: var(--shinra-hinoki-soft);
}
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content h3,
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content p {
    color: var(--shinra-ink) !important;
}
.page-id-127 .shinra-finder--home-magazine .shinra-eyebrow,
.page-id-127 .shinra-finder--home-magazine .shinra-filter-label {
    color: var(--shinra-matcha) !important;
}
.page-id-127 .shinra-finder--home-magazine .shinra-ftag {
    border-color: var(--shinra-hinoki) !important;
    background: var(--shinra-washi) !important;
    color: var(--shinra-ink) !important;
}
.page-id-127 .shinra-finder--home-magazine .shinra-ftag:hover {
    background: var(--shinra-matcha) !important;
    border-color: var(--shinra-matcha) !important;
    color: var(--shinra-washi) !important;
}
.page-id-127 .shinra-finder--home-magazine .shinra-finder-img-label {
    font-size: 20px;
    color: var(--shinra-washi);
    background: linear-gradient(to top, rgba(34,32,29,.45), rgba(111,124,101,.08));
}
.page-id-127 .shinra-home-about {
    max-width: 1080px;
    margin: 92px auto 76px;
    padding: 0 24px;
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 68px;
    align-items: center;
}
.page-id-127 .shinra-home-about-text {
    padding-left: 4px;
}
.page-id-127 .shinra-home-about-kicker {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 15px;
    letter-spacing: 6px;
    color: var(--shinra-ink);
    margin-bottom: 22px;
}
.page-id-127 .shinra-home-about-kicker span {
    color: var(--shinra-seal);
    font-size: 9px;
    vertical-align: middle;
}
.page-id-127 .shinra-home-about h2 {
    font-family: 'Noto Serif TC', serif !important;
    font-size: 28px !important;
    font-weight: 500 !important;
    line-height: 1.9 !important;
    letter-spacing: 5px;
    color: var(--shinra-ink) !important;
    margin: 0 !important;
}
.page-id-127 .shinra-home-about-line {
    width: 34px;
    height: 1px;
    background: var(--shinra-hinoki);
    margin: 24px 0 24px;
}
.page-id-127 .shinra-home-about p {
    font-size: 13.5px;
    line-height: 2.15;
    color: var(--shinra-ink);
    margin: 0 0 14px;
}
.page-id-127 .shinra-home-about-photo {
    overflow: hidden;
    background: var(--shinra-hinoki);
}
.page-id-127 .shinra-home-about-photo img {
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
    display: block;
    filter: none;
}
@media (max-width: 900px) {
    .page-id-127 .shinra-home-hero {
        padding: 0 24px;
    }
    .page-id-127 .shinra-home-mosaic {
        width: 100%;
        height: auto;
        aspect-ratio: 1200 / 378;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        grid-template-rows: repeat(3, 1fr);
    }
    .page-id-127 .shinra-articles--magazine {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 28px 24px !important;
    }
    .page-id-127 .shinra-finder--home-magazine,
    .page-id-127 .shinra-home-about {
        grid-template-columns: 1fr !important;
        gap: 34px;
    }
}
@media (max-width: 560px) {
    .page-id-127 .shinra-home-hero {
        margin-top: 34px;
        padding: 0 18px;
    }
    .page-id-127 .shinra-home-brand {
        margin-bottom: 28px;
    }
    .page-id-127 .shinra-home-brand-title {
        font-size: 17px;
        letter-spacing: 4px;
    }
    .page-id-127 .shinra-home-brand-subtitle {
        font-size: 11px;
        letter-spacing: 3px;
    }
    .page-id-127 .shinra-home-mosaic {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        grid-template-rows: repeat(3, 1fr);
        grid-auto-rows: unset;
        width: 100%;
        height: auto;
        aspect-ratio: 1200 / 378;
    }
    .page-id-127 .shinra-home-mosaic-text {
        grid-column: auto;
        grid-row: auto;
        letter-spacing: 1px;
    }
    .page-id-127 .shinra-home-mosaic-text span {
        font-size: clamp(8px, 2.2vw, 12px);
        line-height: 1.45;
    }
    .page-id-127 .shinra-home-mosaic-text small {
        font-size: clamp(7px, 1.8vw, 10px);
        line-height: 1.35;
    }
    .page-id-127 .shinra-section--latest-magazine,
    .page-id-127 .shinra-finder--home-magazine,
    .page-id-127 .shinra-home-about {
        margin-top: 28px;
        padding-left: 18px;
        padding-right: 18px;
    }
    .page-id-127 .shinra-articles--magazine {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 24px 14px !important;
    }
    .page-id-127 .shinra-articles--magazine .shinra-article-title {
        font-size: 15px !important;
    }
    .page-id-127 .shinra-finder--home-magazine .shinra-finder-content {
        padding: 32px 24px;
    }
    .page-id-127 .shinra-home-about h2 {
        font-size: 23px !important;
        letter-spacing: 3px;
    }
}


/* 2026-04-26: Homepage typography system. */
.page-id-127 {
    --shinra-serif: 'Noto Serif TC', 'Source Han Serif TC', 'Yu Mincho', serif;
    --shinra-sans: 'Hiragino Kaku Gothic ProN', 'Yu Gothic', 'Meiryo', system-ui, -apple-system, BlinkMacSystemFont, 'Noto Sans TC', sans-serif;
}
.page-id-127 .ct-header [data-id="menu"] > ul > li > a {
    font-family: var(--shinra-sans) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    letter-spacing: 1.8px !important;
}
.page-id-127 .ct-header [data-id="mobile-menu"] a {
    font-family: var(--shinra-sans) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 1.75 !important;
    letter-spacing: 1.2px !important;
}
.page-id-127 .shinra-home-brand-title,
.page-id-127 .shinra-home-brand-subtitle,
.page-id-127 .shinra-home-mosaic-text,
.page-id-127 .shinra-home-section-head h2,
.page-id-127 .shinra-articles--magazine .shinra-article-title,
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content h3,
.page-id-127 .shinra-home-about-kicker,
.page-id-127 .shinra-home-about h2,
.page-id-127 .shinra-home-about p {
    font-family: var(--shinra-serif) !important;
}
.page-id-127 .shinra-articles--magazine .shinra-article-date,
.page-id-127 .shinra-finder--home-magazine .shinra-eyebrow,
.page-id-127 .shinra-finder--home-magazine .shinra-filter-label,
.page-id-127 .shinra-finder--home-magazine .shinra-ftag,
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content p {
    font-family: var(--shinra-sans) !important;
}
.page-id-127 .shinra-home-about p {
    font-weight: 400;
    letter-spacing: .35px;
}
.page-id-127 .shinra-finder--home-magazine .shinra-finder-content p {
    letter-spacing: .2px;
}


/* 2026-04-26: Mobile homepage shift visible content up after Hero removal. */
@media (max-width: 560px) {
    .page-id-127 .entry-content > .wp-block-html:first-child {
        display: none !important;
        margin: 0 !important;
        padding: 0 !important;
        height: 0 !important;
    }
    .page-id-127 .shinra-section--latest-magazine:first-of-type,
    .page-id-127 .entry-content > .wp-block-html:first-child + .wp-block-html .shinra-section--latest-magazine {
        margin-top: 6px !important;
    }
    .page-id-127 .shinra-home-section-head {
        margin-bottom: 22px !important;
    }
}


/* === END OpenClaw Gate B5d homepage magazine/mobile CSS === */

/* 2026-05-01: Pull mobile first recipe section upward after hidden Hero/page title. */
@media (max-width: 560px) {
    .page-id-127 .site-main,
    .page-id-127 .ct-container-full[data-vertical-spacing],
    .page-id-127 .ct-container-full[data-vertical-spacing*="top"] {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    .page-id-127 .hero-section,
    .page-id-127 .shinra-home-hero,
    .page-id-127 .entry-content > .wp-block-html:first-child {
        display: none !important;
        height: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    .page-id-127 .shinra-section--latest-magazine:first-of-type,
    .page-id-127 .entry-content > .wp-block-html:first-child + .wp-block-html .shinra-section--latest-magazine {
        margin-top: 0 !important;
    }
}

/* 2026-05-01: rollback unsafe mobile top-pull.
   Do not use negative top/margin-bottom on the first magazine section;
   it can slide the recipe grid under the sticky header and overlap the next section. */
@media (max-width: 689.98px) {
    body.home.page-id-127 {
        --theme-content-vertical-spacing: 0px !important;
    }
    body.home.page-id-127 main#main.site-main,
    body.home.page-id-127 main#main.site-main > .ct-container-full,
    body.home.page-id-127 .ct-container-full[data-content="normal"],
    body.home.page-id-127 article#post-127,
    body.home.page-id-127 article#post-127 > .entry-content {
        margin-top: 0 !important;
        padding-top: 0 !important;
    }
    body.home.page-id-127 main#main.site-main > .hero-section,
    body.home.page-id-127 .hero-section[data-type="type-2"] {
        display: none !important;
        height: 0 !important;
        max-height: 0 !important;
        min-height: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        overflow: hidden !important;
    }
    body.home.page-id-127 .entry-content > .shinra-section--latest-magazine {
        margin-top: 6px !important;
        position: static !important;
        top: auto !important;
        margin-bottom: 28px !important;
    }
}

/* 2026-05-01: Align mobile homepage "查看更多" with section title lower edge. */
@media (max-width: 689.98px) {
    body.home.page-id-127 .shinra-home-section-head {
        display: flex !important;
        align-items: flex-end !important;
        justify-content: space-between !important;
        margin-bottom: 22px !important;
    }
    body.home.page-id-127 .shinra-home-section-head h2 {
        margin: 0 !important;
        line-height: 1.5 !important;
    }
    body.home.page-id-127 .shinra-home-section-head .shinra-section-more {
        line-height: 1 !important;
        margin: 0 !important;
    }
}
