/* =========================================================
   角屋旅館 新潟の人気駅弁(ekiben-niigata01.php)
   File: css/ekiben.css
   v2 - 2026-04-26 — 料亭の品書き仕立て
   依存: header-common.css, footer-common.css
   ========================================================= */

:root{
    --canon-gold: #812913;
    --canon-gold-light: #a73823;
    --canon-gold-deep: #6b1f0f;
    --canon-dark: #2a2a2a;
    --canon-cream: #f8f6f2;
    --canon-brown: #8b7355;
    --canon-gray: #6b6560;
    /* 駅弁ページ専用カラー */
    --ekiben-warm: #faf6ee;
    --ekiben-paper: #fdfaf3;
    --ekiben-paper-deep: #f4eedc;
    --ekiben-deep: #4a3520;
    --ekiben-line: #d4c5a9;
    --ekiben-line-soft: #e8ddc4;
    --ekiben-winter: #e8eef5;
    --ekiben-winter-deep: #3a5475;
    --ekiben-winter-line: #b8c5d4;
}

*{ box-sizing: border-box; }
body{
    background: var(--ekiben-warm);
    color: var(--canon-dark);
    font-family: 'Noto Serif JP', serif;
    line-height: 1.85;
    -webkit-font-smoothing: antialiased;
    margin: 0;
}
img{ max-width: 100%; height: auto; display: block; }
a{ color: inherit; text-decoration: none; }

/* ---------- パンくず ---------- */
.breadcrumb-nav{
    background: rgba(248,246,242,0.95);
    padding: 0.6rem 1.5rem;
    margin-top: 90px;
    border-bottom: 1px solid rgba(212,197,169,.5);
}
.breadcrumb-nav ol{
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin: 0;
    padding: 0;
    font-size: 0.8rem;
    color: var(--canon-gray);
    letter-spacing: 0.05em;
}
.breadcrumb-nav li + li::before{
    content: "›";
    padding: 0 .4em;
    color: var(--canon-brown);
}
.breadcrumb-nav a{ color: var(--canon-brown); }
.breadcrumb-nav a:hover{ text-decoration: underline; }
@media (max-width: 768px){
    .breadcrumb-nav{ margin-top: 60px; padding: 0.5rem 1rem; }
}

/* =========================================================
   共通: 装飾マーク(セクション間の区切り)
   ========================================================= */
.ekiben-section-mark{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin: 0 auto 2.5rem;
    max-width: 200px;
}
.ekiben-section-mark-line{
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--canon-gold), transparent);
    opacity: .5;
}
.ekiben-section-mark-rhombus{
    width: 8px;
    height: 8px;
    background: var(--canon-gold);
    transform: rotate(45deg);
    opacity: .85;
    flex-shrink: 0;
}

/* =========================================================
   共通: 強調表現(emp = 金色細下線+太字)
   ========================================================= */
.emp{
    color: var(--canon-gold);
    font-weight: 600;
    border-bottom: 1px solid rgba(129,41,19,.25);
    padding-bottom: 1px;
    text-decoration: none;
}
.emp-light{
    color: rgba(255,230,200,.95);
    border-bottom-color: rgba(255,230,200,.3);
}

/* =========================================================
   HERO
   ========================================================= */
.ekiben-hero{
    position: relative;
    min-height: 60vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--ekiben-deep);
}
.ekiben-hero-bg{
    position: absolute;
    inset: 0;
    background-image: url('image2/ekiben/ekiben01.webp'),
                      url('image/ekiben/ekiben01.jpg');
    background-size: cover;
    background-position: center;
    filter: brightness(.42) saturate(.92) contrast(1.05);
    z-index: 1;
}
.ekiben-hero-overlay{
    position: absolute;
    inset: 0;
    z-index: 2;
    background:
        linear-gradient(180deg,
            rgba(35,25,15,.5) 0%,
            rgba(35,25,15,.18) 30%,
            rgba(30,20,10,.05) 55%,
            rgba(25,15,5,.7) 100%);
}

.ekiben-hero-content{
    position: relative;
    z-index: 3;
    text-align: center;
    color: #fff;
    padding: 5rem 1.5rem;
    max-width: 760px;
    width: 100%;
}
.ekiben-hero-eyebrow{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin: 0 auto 2.2rem;
    max-width: 460px;
}
.ekiben-hero-eyebrow-line{
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,220,180,.5), transparent);
}
.ekiben-hero-eyebrow-text{
    font-family: 'Cinzel', serif;
    font-size: .65rem;
    letter-spacing: .4em;
    color: rgba(255,220,180,.85);
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}
.ekiben-hero-title{
    margin: 0 0 1.8rem;
    line-height: 1.2;
}
.ekiben-hero-title-main{
    display: block;
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(2.2rem, 6.5vw, 3.8rem);
    letter-spacing: .14em;
    color: #fff;
    text-shadow: 0 2px 28px rgba(0,0,0,.5);
    margin-bottom: 1.1rem;
}
.ekiben-hero-title-main::after{
    content: "";
    display: block;
    width: 60px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,220,180,.7), transparent);
    margin: 1.5rem auto 0;
}
.ekiben-hero-title-sub{
    display: block;
    font-family: 'Shippori Mincho', serif;
    font-size: clamp(.85rem, 2.2vw, 1.05rem);
    letter-spacing: .22em;
    color: rgba(255,220,180,.78);
    font-weight: 400;
}
.ekiben-hero-lead{
    font-family: 'Shippori Mincho', serif;
    font-size: clamp(.92rem, 2.2vw, 1.05rem);
    line-height: 2.15;
    color: rgba(255,250,240,.88);
    letter-spacing: .1em;
    margin: 0;
    text-shadow: 0 1px 12px rgba(0,0,0,.55);
}
@media (max-width: 768px){
    .ekiben-hero{ min-height: 55vh; }
    .ekiben-hero-content{ padding: 3.5rem 1rem; }
    .ekiben-hero-eyebrow{ gap: .8rem; max-width: 360px; }
    .ekiben-hero-eyebrow-text{ font-size: .55rem; letter-spacing: .3em; }
    .ekiben-hero-title-main{ letter-spacing: .08em; }
    .ekiben-hero-title-sub{ letter-spacing: .15em; }
    .ekiben-hero-lead{ font-size: .88rem; line-height: 2; letter-spacing: .06em; }
}
@media (max-width: 380px){
    .ekiben-hero-title-main{ font-size: 1.85rem; letter-spacing: .06em; }
    .ekiben-hero-title-sub{ font-size: .75rem; }
    .ekiben-hero-eyebrow-text{ font-size: .5rem; letter-spacing: .25em; }
}

/* =========================================================
   INTRO
   ========================================================= */
.ekiben-intro{
    padding: 5rem 1.5rem 6rem;
    background: var(--ekiben-paper);
    position: relative;
}
.ekiben-intro-inner{
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}
.ekiben-intro-lead{
    font-family: 'Shippori Mincho', serif;
    font-size: 1.18rem;
    line-height: 2.2;
    color: var(--canon-dark);
    letter-spacing: .1em;
    margin: 0 0 2.5rem;
    padding-bottom: 2.5rem;
    border-bottom: 1px solid rgba(212,197,169,.45);
    position: relative;
}
.ekiben-intro-lead::after{
    content: "";
    position: absolute;
    bottom: -1px;
    left: 50%;
    width: 50px;
    height: 1px;
    background: var(--canon-gold);
    transform: translateX(-50%);
    opacity: .8;
}
.ekiben-intro-text{
    font-family: 'Shippori Mincho', serif;
    font-size: .96rem;
    line-height: 2.15;
    color: var(--canon-dark);
    letter-spacing: .06em;
    margin: 0 0 1.5em;
    text-align: left;
}
.ekiben-intro-text:last-child{ margin-bottom: 0; }
@media (max-width: 768px){
    .ekiben-intro{ padding: 3.5rem 1.2rem 4rem; }
    .ekiben-intro-lead{ font-size: 1.02rem; line-height: 2; letter-spacing: .06em; }
    .ekiben-intro-text{ font-size: .9rem; line-height: 2.05; }
}

/* =========================================================
   駅弁カード(共通)
   ========================================================= */
.ekiben-card{
    padding: 6rem 1.5rem;
    background: var(--ekiben-paper);
    border-top: 1px solid rgba(212,197,169,.4);
    position: relative;
}
.ekiben-card:nth-of-type(2n){
    background:
        linear-gradient(180deg, var(--ekiben-warm) 0%, var(--ekiben-paper) 100%);
}
.ekiben-card-inner{
    max-width: 880px;
    margin: 0 auto;
}

/* ---- ヘッダ部(壱・弐・参・四 + 販売元 + タイトル + tagline) ---- */
.ekiben-card-header{
    text-align: center;
    margin-bottom: 3.5rem;
    padding-bottom: 0;
}

/* 番号(壱・弐・参・四) */
.ekiben-card-numeral{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.4rem;
    margin: 0 auto 1.8rem;
    max-width: 240px;
}
.ekiben-card-numeral-line{
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--canon-gold), transparent);
    opacity: .55;
}
.ekiben-card-numeral-kanji{
    font-family: 'Shippori Mincho', serif;
    font-weight: 600;
    font-size: 1.4rem;
    color: var(--canon-gold);
    letter-spacing: .15em;
    flex-shrink: 0;
    line-height: 1;
    padding: 0 .4em;
}

/* 販売元(タイトル上の小さめのラベル) */
.ekiben-card-vendor{
    margin: 0 0 1rem;
    text-align: center;
}
.ekiben-card-vendor span{
    display: inline-block;
    font-family: 'Shippori Mincho', serif;
    font-size: .82rem;
    color: var(--canon-brown);
    letter-spacing: .35em;
    text-indent: .35em;
    padding: .35rem 1.6rem .4rem;
    border-top: 1px solid rgba(139,115,85,.35);
    border-bottom: 1px solid rgba(139,115,85,.35);
}

/* 季節ラベル */
.ekiben-card-season{
    font-family: 'Cinzel', serif;
    font-size: .58rem;
    letter-spacing: .35em;
    color: var(--ekiben-winter-deep);
    text-transform: uppercase;
    margin: .8rem 0 1.2rem;
    text-align: center;
    font-style: italic;
    opacity: .85;
}

/* タイトル */
.ekiben-card-title{
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(1.7rem, 4vw, 2.4rem);
    letter-spacing: .15em;
    color: var(--canon-dark);
    line-height: 1.5;
    margin: 0 0 1.2rem;
}
.ekiben-card-hero .ekiben-card-title{
    font-size: clamp(2rem, 5vw, 2.8rem);
    font-weight: 500;
}

/* tagline */
.ekiben-card-tagline{
    font-family: 'Shippori Mincho', serif;
    font-size: .9rem;
    color: var(--canon-brown);
    letter-spacing: .15em;
    margin: 0;
    font-style: italic;
}
.ekiben-card-tagline::before,
.ekiben-card-tagline::after{
    content: "—";
    margin: 0 .8em;
    color: var(--ekiben-line);
    font-style: normal;
}

@media (max-width: 768px){
    .ekiben-card-header{ margin-bottom: 2.5rem; }
    .ekiben-card-numeral-kanji{ font-size: 1.2rem; }
    .ekiben-card-vendor span{ font-size: .72rem; padding: .3rem 1.2rem; }
    .ekiben-card-tagline{ font-size: .82rem; }
    .ekiben-card-tagline::before,
    .ekiben-card-tagline::after{ margin: 0 .5em; }
}

/* ---- メイン画像 ---- */
.ekiben-card-hero-image{
    margin: 0 0 3rem;
    border-radius: 2px;
    overflow: hidden;
    box-shadow:
        0 1px 0 rgba(255,255,255,.8) inset,
        0 18px 50px rgba(40,28,15,.18),
        0 4px 12px rgba(40,28,15,.08);
    position: relative;
    border: 1px solid rgba(212,197,169,.4);
}
.ekiben-card-hero-image img{
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    background: var(--canon-cream);
    transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.ekiben-card-hero-image:hover img{ transform: scale(1.02); }
.ekiben-card-hero-image figcaption{
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 1.5rem;
    background: linear-gradient(180deg, transparent, rgba(20,15,10,.75));
    color: rgba(255,250,245,.92);
    font-family: 'Shippori Mincho', serif;
    font-size: .82rem;
    letter-spacing: .15em;
    text-align: center;
}

/* ---- 本文 ---- */
.ekiben-card-body{
    max-width: 720px;
    margin: 0 auto 3rem;
    font-size: 1rem;
    line-height: 2.15;
    color: var(--canon-dark);
    letter-spacing: .06em;
}
.ekiben-card-text{
    margin: 0 0 1.5em;
    font-family: 'Shippori Mincho', serif;
}
.ekiben-card-text:last-child{ margin-bottom: 0; }
.ekiben-card-text-center{
    text-align: center;
    color: var(--canon-gold);
    font-weight: 500;
    letter-spacing: .15em;
    margin-bottom: 1.8em !important;
    font-size: 1.05em;
}
.ekiben-card-text-small{
    margin: 1.8em 0 0;
    font-size: .82rem;
    line-height: 1.95;
    color: var(--canon-gray);
    padding: 1.2rem 1.5rem;
    background: rgba(212,197,169,.12);
    border-left: 2px solid var(--ekiben-line);
    border-radius: 0 2px 2px 0;
    letter-spacing: .04em;
}

/* ---- 命名表(まさかいくらなんでも寿司) ---- */
.naming-table-wrap{
    max-width: 480px;
    margin: 0 auto 2.5rem;
    padding: 2.5rem 2rem 2rem;
    background:
        linear-gradient(180deg, #fffdf6 0%, var(--ekiben-paper-deep) 100%);
    border: 1px solid rgba(212,197,169,.55);
    position: relative;
    box-shadow:
        0 1px 0 rgba(255,255,255,.8) inset,
        0 8px 24px rgba(40,28,15,.06);
}
.naming-table-wrap::before,
.naming-table-wrap::after{
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    border: 1px solid var(--canon-gold);
    opacity: .5;
}
.naming-table-wrap::before{
    top: 8px; left: 8px;
    border-right: none;
    border-bottom: none;
}
.naming-table-wrap::after{
    bottom: 8px; right: 8px;
    border-left: none;
    border-top: none;
}
.naming-table-caption{
    text-align: center;
    font-family: 'Shippori Mincho', serif;
    font-size: .85rem;
    color: var(--canon-gold);
    letter-spacing: .25em;
    text-indent: .25em;
    margin: 0 0 1.5rem;
    font-style: normal;
    padding-bottom: 1rem;
    border-bottom: 1px dotted rgba(212,197,169,.6);
}
.naming-table{
    width: 100%;
    border-collapse: collapse;
}
.naming-table th,
.naming-table td{
    padding: .85rem 0;
    border-bottom: 1px dotted rgba(212,197,169,.5);
    vertical-align: middle;
    background: transparent;
}
.naming-table tr:last-child th,
.naming-table tr:last-child td{ border-bottom: none; }
.naming-table th{
    width: 40%;
    text-align: left;
    padding-right: 1.5rem;
}
.naming-table-letter{
    display: inline-block;
    font-family: 'Shippori Mincho', serif;
    font-weight: 600;
    font-size: 1.25rem;
    color: var(--canon-gold);
    letter-spacing: .12em;
    line-height: 1;
}
.naming-table td{
    text-align: left;
    padding-left: 1rem;
    border-left: 1px solid rgba(212,197,169,.4);
}
.naming-kanji{
    display: inline;
    font-family: 'Shippori Mincho', serif;
    font-size: 1.05rem;
    color: var(--canon-dark);
    letter-spacing: .08em;
    margin-right: .6em;
}
.naming-yomi{
    display: inline-block;
    font-family: 'Shippori Mincho', serif;
    font-size: .72rem;
    color: var(--canon-brown);
    letter-spacing: .15em;
    vertical-align: middle;
}
@media (max-width: 540px){
    .naming-table-wrap{ padding: 2rem 1.4rem 1.5rem; }
    .naming-table th{ width: 45%; padding-right: .8rem; }
    .naming-table td{ padding-left: .7rem; }
    .naming-table-letter{ font-size: 1.1rem; }
    .naming-kanji{ font-size: .95rem; }
    .naming-yomi{ font-size: .68rem; }
}

/* ---- 2枚並びギャラリー ---- */
.ekiben-card-gallery{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
    margin: 0 auto 3rem;
    max-width: 800px;
}
.ekiben-card-gallery figure{
    margin: 0;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 6px 20px rgba(40,28,15,.08);
    border: 1px solid rgba(212,197,169,.3);
}
.ekiben-card-gallery img{
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    background: var(--canon-cream);
    transition: transform 1s cubic-bezier(.2,.8,.2,1);
}
.ekiben-card-gallery figure:hover img{ transform: scale(1.04); }

/* 4枚グリッド(雪だるま用) */
.ekiben-card-gallery-quad{ grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px){
    .ekiben-card-gallery-quad{ grid-template-columns: repeat(4, 1fr); gap: .9rem; }
}
@media (max-width: 540px){
    .ekiben-card-gallery{ grid-template-columns: 1fr; gap: .9rem; }
    .ekiben-card-gallery-quad{ grid-template-columns: 1fr 1fr; gap: .7rem; }
}

/* ---- ワイド画像 ---- */
.ekiben-card-image-wide{
    margin: 0 auto 3rem;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(40,28,15,.1);
    max-width: 880px;
    border: 1px solid rgba(212,197,169,.4);
}
.ekiben-card-image-wide img{
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    background: var(--canon-cream);
}

/* ---- 動画埋め込み ---- */
.ekiben-card-video{
    margin: 0 auto 3rem;
    max-width: 720px;
}
.ekiben-card-video-label{
    text-align: center;
    margin: 0 0 1.2rem;
}
.ekiben-card-video-label span{
    display: inline-block;
    font-family: 'Shippori Mincho', serif;
    font-size: .8rem;
    color: var(--canon-brown);
    letter-spacing: .35em;
    text-indent: .35em;
    padding: 0 1.5rem;
    position: relative;
}
.ekiben-card-video-label span::before,
.ekiben-card-video-label span::after{
    content: "";
    position: absolute;
    top: 50%;
    width: 30px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--ekiben-line));
}
.ekiben-card-video-label span::before{
    right: 100%;
    background: linear-gradient(90deg, transparent, var(--ekiben-line));
}
.ekiben-card-video-label span::after{
    left: 100%;
    background: linear-gradient(90deg, var(--ekiben-line), transparent);
}
.ekiben-video-wrap{
    position: relative;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 12px 32px rgba(40,28,15,.18);
    border: 1px solid rgba(212,197,169,.4);
}
.ekiben-video-wrap iframe{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* =========================================================
   弁当屋カード(料亭の名刺風) ★ HANA要望の核心 ★
   ========================================================= */
.vendor-card{
    position: relative;
    max-width: 460px;
    margin: 1rem auto 0;
    padding: 3.2rem 2.5rem 2.6rem;
    background:
        linear-gradient(180deg, #fffefa 0%, #faf3e3 100%);
    border: 1px solid rgba(212,197,169,.55);
    box-shadow:
        0 1px 0 rgba(255,255,255,.9) inset,
        0 0 0 1px rgba(212,197,169,.15) inset,
        0 2px 4px rgba(40,28,15,.04),
        0 18px 38px rgba(40,28,15,.12),
        0 36px 60px rgba(40,28,15,.08);
}

/* 四隅の装飾(角の銘) */
.vendor-card-corner{
    position: absolute;
    width: 16px;
    height: 16px;
    border: 1px solid var(--canon-gold);
    opacity: .55;
    pointer-events: none;
}
.vendor-card-corner-tl{ top: 12px; left: 12px; border-right: none; border-bottom: none; }
.vendor-card-corner-tr{ top: 12px; right: 12px; border-left: none; border-bottom: none; }
.vendor-card-corner-bl{ bottom: 12px; left: 12px; border-right: none; border-top: none; }
.vendor-card-corner-br{ bottom: 12px; right: 12px; border-left: none; border-top: none; }

/* eyebrow(販売元 / Vendor の二段表記) */
.vendor-card-eyebrow{
    text-align: center;
    margin: 0 0 1.6rem;
    line-height: 1.2;
}
.vendor-card-eyebrow-jp{
    display: block;
    font-family: 'Shippori Mincho', serif;
    font-size: .75rem;
    color: var(--canon-brown);
    letter-spacing: .8em;
    text-indent: .8em;
    margin-bottom: .5rem;
    font-weight: 500;
}
.vendor-card-eyebrow-en{
    display: block;
    font-family: 'Cinzel', serif;
    font-size: .56rem;
    color: var(--canon-brown);
    letter-spacing: .45em;
    text-transform: uppercase;
    text-indent: .45em;
    opacity: .65;
}

/* 販売元名(中央に大きく) */
.vendor-card-name{
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(1.55rem, 3.2vw, 1.85rem);
    color: var(--canon-dark);
    letter-spacing: .25em;
    text-indent: .25em;
    text-align: center;
    margin: 0 0 1rem;
    line-height: 1.5;
}

/* 公式サイトリンク */
.vendor-card-website{
    display: block;
    text-align: center;
    margin-bottom: 2rem;
    transition: opacity .35s ease;
}
.vendor-card-website span{
    display: inline-block;
    font-family: 'Cinzel', serif;
    font-size: .56rem;
    letter-spacing: .42em;
    color: var(--canon-gold);
    text-transform: uppercase;
    text-indent: .42em;
    padding-bottom: .4rem;
    border-bottom: 1px solid rgba(129,41,19,.4);
    transition: border-color .35s, letter-spacing .35s;
}
.vendor-card-website:hover span{
    border-bottom-color: var(--canon-gold);
    letter-spacing: .48em;
}

/* 区切り線(中央に菱形) */
.vendor-card-divider{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin: 0 auto 2rem;
    max-width: 280px;
}
.vendor-card-divider-line{
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(212,197,169,.7), transparent);
}
.vendor-card-divider-mark{
    width: 7px;
    height: 7px;
    border: 1px solid var(--canon-gold);
    transform: rotate(45deg);
    flex-shrink: 0;
    background: rgba(255,255,255,.5);
}

/* 詳細情報(電話・所在地) */
.vendor-card-details{
    margin: 0;
    padding: 0;
}
.vendor-card-detail-row{
    display: grid;
    grid-template-columns: 4.5em 1fr;
    align-items: baseline;
    gap: 1.4rem;
    padding: .7rem 0;
    border-bottom: 1px dotted rgba(212,197,169,.55);
}
.vendor-card-detail-row:last-child{ border-bottom: none; }
.vendor-card-details dt{
    font-family: 'Shippori Mincho', serif;
    font-size: .72rem;
    color: var(--canon-brown);
    letter-spacing: .35em;
    text-indent: .35em;
    margin: 0;
    font-weight: 500;
}
.vendor-card-details dd{
    font-family: 'Shippori Mincho', serif;
    font-size: .92rem;
    color: var(--canon-dark);
    margin: 0;
    letter-spacing: .04em;
    line-height: 1.6;
}
.vendor-card-details dd a{
    color: var(--canon-gold);
    border-bottom: 1px solid transparent;
    transition: border-color .3s;
    font-weight: 500;
    letter-spacing: .08em;
}
.vendor-card-details dd a:hover{ border-bottom-color: var(--canon-gold); }

/* 雪だるま弁当用の冬色バリエーション */
.vendor-card-winter{
    background:
        linear-gradient(180deg, #fdfeff 0%, #e8eef5 100%);
    border-color: rgba(184,197,212,.65);
}
.vendor-card-winter .vendor-card-corner{
    border-color: var(--ekiben-winter-deep);
}
.vendor-card-winter .vendor-card-eyebrow-jp,
.vendor-card-winter .vendor-card-eyebrow-en,
.vendor-card-winter .vendor-card-details dt{
    color: var(--ekiben-winter-deep);
    opacity: .8;
}
.vendor-card-winter .vendor-card-website span{
    color: var(--ekiben-winter-deep);
    border-bottom-color: rgba(58,84,117,.4);
}
.vendor-card-winter .vendor-card-website:hover span{ border-bottom-color: var(--ekiben-winter-deep); }
.vendor-card-winter .vendor-card-divider-mark{
    border-color: var(--ekiben-winter-deep);
    background: rgba(255,255,255,.6);
}
.vendor-card-winter .vendor-card-details dd a{ color: var(--ekiben-winter-deep); }
.vendor-card-winter .vendor-card-details dd a:hover{ border-bottom-color: var(--ekiben-winter-deep); }

@media (max-width: 540px){
    .vendor-card{
        padding: 2.6rem 1.6rem 2rem;
        max-width: none;
    }
    .vendor-card-name{ font-size: 1.4rem; letter-spacing: .18em; text-indent: .18em; }
    .vendor-card-eyebrow-jp{ font-size: .68rem; letter-spacing: .6em; text-indent: .6em; }
    .vendor-card-detail-row{ grid-template-columns: 4em 1fr; gap: .9rem; }
    .vendor-card-details dd{ font-size: .85rem; }
}

/* =========================================================
   雪だるま弁当の特別装飾(冬の色)
   ========================================================= */
.ekiben-card-winter{
    background:
        linear-gradient(180deg, var(--ekiben-paper) 0%, var(--ekiben-winter) 100%);
}
.ekiben-card-winter .ekiben-card-numeral-line{
    background: linear-gradient(90deg, transparent, var(--ekiben-winter-deep), transparent);
}
.ekiben-card-winter .ekiben-card-numeral-kanji{
    color: var(--ekiben-winter-deep);
}
.ekiben-card-winter .ekiben-card-vendor span{
    color: var(--ekiben-winter-deep);
    border-color: rgba(58,84,117,.35);
}
.ekiben-card-winter .ekiben-card-text .emp{
    color: var(--ekiben-winter-deep);
    border-bottom-color: rgba(58,84,117,.3);
}

@media (max-width: 768px){
    .ekiben-card{ padding: 4rem 1rem; }
}

/* =========================================================
   RELATED — 関連カード
   ========================================================= */
.ekiben-related{
    padding: 6rem 1.5rem;
    background: var(--ekiben-warm);
    border-top: 1px solid rgba(212,197,169,.4);
}
.ekiben-related-inner{
    max-width: 1100px;
    margin: 0 auto;
}

.ekiben-section-head{
    text-align: center;
    margin-bottom: 3.5rem;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}
.ekiben-section-en{
    font-family: 'Cinzel', serif;
    font-size: .65rem;
    letter-spacing: .5em;
    color: var(--canon-brown);
    text-transform: uppercase;
    text-indent: .5em;
    margin: 0 0 1.2rem;
    opacity: .75;
}
.ekiben-section-title{
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(1.6rem, 3.5vw, 2.2rem);
    letter-spacing: .15em;
    color: var(--canon-dark);
    line-height: 1.5;
    margin: 0 0 1.2rem;
}
.ekiben-section-title::after{
    content: "";
    display: block;
    width: 42px;
    height: 1px;
    background: var(--canon-gold);
    margin: 1.4rem auto 0;
    opacity: .7;
}
.ekiben-section-lead{
    font-family: 'Shippori Mincho', serif;
    font-size: .93rem;
    letter-spacing: .1em;
    color: var(--canon-gray);
    margin: 0;
}

.ekiben-related-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.8rem;
}
.ekiben-related-card{
    background: #fff;
    border-radius: 2px;
    overflow: hidden;
    transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
    box-shadow:
        0 1px 0 rgba(255,255,255,.8) inset,
        0 4px 18px rgba(40,28,15,.07);
    border: 1px solid rgba(212,197,169,.4);
    text-decoration: none;
    color: inherit;
}
.ekiben-related-card:hover{
    transform: translateY(-4px);
    box-shadow:
        0 1px 0 rgba(255,255,255,.8) inset,
        0 14px 32px rgba(40,28,15,.13);
    color: inherit;
}
.ekiben-related-card-image{
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--canon-cream);
    position: relative;
}
.ekiben-related-card-image::after{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.08));
    pointer-events: none;
}
.ekiben-related-card-image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1s cubic-bezier(.2,.8,.2,1);
}
.ekiben-related-card:hover .ekiben-related-card-image img{ transform: scale(1.05); }
.ekiben-related-card-body{
    padding: 1.4rem 1.5rem 1.6rem;
}
.ekiben-related-card-en{
    font-family: 'Cinzel', serif;
    font-size: .58rem;
    letter-spacing: .4em;
    color: var(--canon-brown);
    text-transform: uppercase;
    text-indent: .4em;
    margin: 0 0 .5rem;
    opacity: .75;
}
.ekiben-related-card-name{
    font-family: 'Shippori Mincho', serif;
    font-size: 1.08rem;
    font-weight: 500;
    color: var(--canon-dark);
    letter-spacing: .12em;
    margin: 0 0 .9rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid rgba(212,197,169,.5);
}
.ekiben-related-card-desc{
    font-family: 'Shippori Mincho', serif;
    font-size: .82rem;
    line-height: 1.85;
    color: var(--canon-gray);
    margin: 0;
    letter-spacing: .04em;
}

@media (max-width: 900px){
    .ekiben-related-grid{ grid-template-columns: 1fr 1fr; gap: 1.4rem; }
}
@media (max-width: 600px){
    .ekiben-related{ padding: 4rem 1rem; }
    .ekiben-related-grid{ grid-template-columns: 1fr; gap: 1rem; }
}

/* =========================================================
   OUTRO — 結びの一行
   ========================================================= */
.ekiben-outro{
    padding: 5rem 1.5rem;
    background: var(--ekiben-paper);
    text-align: center;
    border-top: 1px solid rgba(212,197,169,.3);
}
.ekiben-outro-inner{
    max-width: 600px;
    margin: 0 auto;
}
.ekiben-outro-text{
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(1.15rem, 2.8vw, 1.4rem);
    color: var(--canon-dark);
    letter-spacing: .18em;
    line-height: 1.9;
    margin: 0 0 1rem;
}
.ekiben-outro-text-en{
    font-family: 'Cinzel', serif;
    font-style: italic;
    font-size: .7rem;
    letter-spacing: .3em;
    color: var(--canon-brown);
    margin: 0;
    opacity: .75;
}

/* =========================================================
   KADOYA-CONNECTION — 角屋旅館への上品な誘導
   ========================================================= */
.ekiben-kadoya{
    padding: 6rem 1.5rem;
    background:
        linear-gradient(135deg, var(--canon-gold) 0%, var(--canon-gold-deep) 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
    text-align: center;
}
.ekiben-kadoya::before{
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 80% 20%, rgba(255,220,180,.12), transparent 50%),
        radial-gradient(circle at 20% 80%, rgba(255,180,140,.08), transparent 50%);
    pointer-events: none;
}
/* 背景の波紋的な装飾 */
.ekiben-kadoya::after{
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 200px;
    height: 200px;
    border: 1px solid rgba(255,220,180,.08);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}
.ekiben-kadoya-inner{
    max-width: 720px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.ekiben-kadoya-eyebrow{
    font-family: 'Cinzel', serif;
    font-style: italic;
    font-size: .65rem;
    letter-spacing: .4em;
    color: rgba(255,220,180,.78);
    text-transform: uppercase;
    margin: 0 0 1.4rem;
}
.ekiben-kadoya-title{
    font-family: 'Shippori Mincho', serif;
    font-weight: 500;
    font-size: clamp(1.7rem, 4vw, 2.3rem);
    letter-spacing: .18em;
    line-height: 1.7;
    color: #fff;
    margin: 0 0 1.5rem;
}
.ekiben-kadoya-title::after{
    content: "";
    display: block;
    width: 50px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,220,180,.7), transparent);
    margin: 1.6rem auto 0;
}
.ekiben-kadoya-text{
    font-family: 'Shippori Mincho', serif;
    font-size: .98rem;
    line-height: 2.15;
    color: rgba(255,250,240,.88);
    letter-spacing: .08em;
    margin: 0 0 3.2rem;
}

/* CTA カード(同等の重要度で並列) */
.ekiben-kadoya-cta{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
    max-width: 560px;
    margin: 0 auto;
}
.ekiben-kadoya-cta-card{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: var(--canon-gold);
    padding: 1.9rem 1.3rem 1.5rem;
    border-radius: 3px;
    text-decoration: none;
    transition: all .4s cubic-bezier(.2,.8,.2,1);
    box-shadow:
        0 1px 0 rgba(255,255,255,.7) inset,
        0 8px 24px rgba(0,0,0,.18),
        0 2px 6px rgba(0,0,0,.1);
    text-align: center;
    min-height: 170px;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(212,197,169,.4);
}
.ekiben-kadoya-cta-card::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--canon-gold), var(--canon-gold-light), var(--canon-gold));
    transition: height .35s ease;
}
.ekiben-kadoya-cta-card::after{
    content: "→";
    position: absolute;
    bottom: .9rem;
    right: 1.1rem;
    font-family: 'Cinzel', serif;
    font-size: .9rem;
    color: var(--canon-gold);
    opacity: .35;
    transition: all .35s;
}
.ekiben-kadoya-cta-card:hover{
    transform: translateY(-4px);
    box-shadow:
        0 1px 0 rgba(255,255,255,.7) inset,
        0 16px 36px rgba(0,0,0,.25),
        0 4px 12px rgba(0,0,0,.15);
    color: var(--canon-gold);
}
.ekiben-kadoya-cta-card:hover::before{ height: 4px; }
.ekiben-kadoya-cta-card:hover::after{
    opacity: 1;
    transform: translateX(4px);
}
.ekiben-kadoya-cta-card-eyebrow{
    display: block;
    font-family: 'Cinzel', serif;
    font-style: italic;
    font-size: .56rem;
    letter-spacing: .42em;
    color: var(--canon-brown);
    text-transform: uppercase;
    text-indent: .42em;
    margin-bottom: .65rem;
}
.ekiben-kadoya-cta-card-title{
    display: block;
    font-family: 'Shippori Mincho', serif;
    font-size: 1.12rem;
    font-weight: 500;
    letter-spacing: .15em;
    text-indent: .15em;
    color: var(--canon-dark);
    margin-bottom: .65rem;
    line-height: 1.5;
}
.ekiben-kadoya-cta-card-title::after{
    content: "";
    display: block;
    width: 24px;
    height: 1px;
    background: var(--canon-gold);
    margin: .55rem auto 0;
    opacity: .55;
    transition: width .35s ease, opacity .35s ease;
}
.ekiben-kadoya-cta-card:hover .ekiben-kadoya-cta-card-title::after{
    width: 38px;
    opacity: 1;
}
.ekiben-kadoya-cta-card-text{
    display: block;
    font-family: 'Shippori Mincho', serif;
    font-size: .8rem;
    color: var(--canon-gray);
    letter-spacing: .06em;
    line-height: 1.7;
}

@media (max-width: 540px){
    .ekiben-kadoya{ padding: 4rem 1rem; }
    .ekiben-kadoya-cta{
        grid-template-columns: 1fr;
        gap: .9rem;
    }
    .ekiben-kadoya-cta-card{
        min-height: 0;
        padding: 1.6rem 1.2rem 1.4rem;
    }
}

/* =========================================================
   モーション削減対応
   ========================================================= */
@media (prefers-reduced-motion: reduce){
    *,
    *::before,
    *::after{
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
}