/* /blog/ — Ichis HP/LP準拠 フルブリード */
/* style.css:1122 の .page{max-width:520px} がWordPress自動付与の body.page に誤適用されるのを解除 */
body.page-id-366{max-width:none !important;padding:0 !important;width:100%}
body.page-id-366 .page-main{max-width:none;width:100%}
.bl-wrap{background:#FFFFFF;color:#1A1A1A;-webkit-font-smoothing:antialiased;margin-top:90px}
.bl-wrap *{box-sizing:border-box}
.bl-inner{max-width:1280px;margin:0 auto;padding:0 40px}
@media (max-width:760px){.bl-inner{padding:0 20px}}
.bl-dot{display:inline-block;width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.4;margin:0 2px}
.bl-arrow{display:inline-block;transition:transform .3s}

/* HERO */
.bl-hero{position:relative;width:100%;min-height:56vh;padding:clamp(80px,12vw,140px) 40px;background:#0F192D;background-size:cover;background-position:center;color:#FFF;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.bl-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.35) 100%);pointer-events:none}
.bl-hero-inner{position:relative;max-width:900px;width:100%}
.bl-hero-eyebrow{font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.35em;color:rgba(255,255,255,.65);margin:0 0 32px;text-transform:uppercase}
.bl-hero-title{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(64px,13vw,160px);line-height:.92;letter-spacing:.03em;color:#FFF;margin:0 0 28px;text-shadow:0 4px 40px rgba(0,0,0,.4)}
.bl-hero-sub{font-family:'Noto Serif JP',serif;font-weight:500;font-size:clamp(14px,1.4vw,17px);line-height:2;color:rgba(255,255,255,.85);margin:0 auto 40px;max-width:640px;letter-spacing:.03em}
.bl-hero-meta{display:inline-flex;align-items:center;gap:24px;font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.2em;color:rgba(255,255,255,.75);padding:16px 32px;border-top:1px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.25)}
.bl-hero-meta-num{font-size:20px;color:#FFF;font-variant-numeric:tabular-nums;margin-right:6px;letter-spacing:.04em}
.bl-hero-meta-sep{width:1px;height:14px;background:rgba(255,255,255,.3)}
@media (max-width:760px){
.bl-hero{min-height:44vh;padding:80px 20px}
.bl-hero-eyebrow{font-size:10px;margin-bottom:20px;letter-spacing:.28em}
.bl-hero-sub{font-size:13px;line-height:1.9;margin-bottom:28px}
.bl-hero-meta{gap:14px;padding:12px 20px;font-size:10px;letter-spacing:.15em}
.bl-hero-meta-num{font-size:16px}
}

/* FILTER */
.bl-filter-bar{position:sticky;top:90px;z-index:20;background:#FFF;border-bottom:1px solid #E5E5E5}
.bl-filter{display:flex;gap:0;justify-content:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.bl-filter::-webkit-scrollbar{display:none}
.bl-filter a{display:inline-flex;align-items:center;gap:10px;padding:22px 28px;font-family:'Noto Serif JP',serif;font-weight:600;font-size:14px;color:#888;letter-spacing:.05em;white-space:nowrap;flex-shrink:0;transition:color .2s;position:relative}
.bl-filter a:hover{color:#1A1A1A}
.bl-filter a.is-active{color:#1B3A6B;font-weight:700}
.bl-filter a.is-active::after{content:'';position:absolute;left:20px;right:20px;bottom:-1px;height:2px;background:#1B3A6B}
.bl-filter-count{font-family:'Playfair Display',serif;font-weight:700;font-size:10px;color:#BBB;letter-spacing:.08em;padding:2px 8px;border:1px solid #E5E5E5;border-radius:999px;font-variant-numeric:tabular-nums}
.bl-filter a.is-active .bl-filter-count{color:#1B3A6B;border-color:#1B3A6B}
@media (max-width:760px){
.bl-filter-bar{position:static}
.bl-filter{justify-content:flex-start;padding:0 12px}
.bl-filter a{padding:16px 14px;font-size:13px;gap:6px}
.bl-filter a.is-active::after{left:10px;right:10px}
.bl-filter-count{font-size:9px;padding:1px 6px}
}

/* FEATURED */
.bl-featured{position:relative;width:100%;background:#FAFAFA}
.bl-featured-link{display:grid;grid-template-columns:1.35fr 1fr;min-height:560px;text-decoration:none;color:inherit}
.bl-featured-media{position:relative;background-size:cover;background-position:center;background-color:#1A1A1A;overflow:hidden;transition:transform 1s cubic-bezier(.2,.6,.2,1)}
.bl-featured-media::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,0) 40%,rgba(250,250,250,.4) 100%)}
.bl-featured-link:hover .bl-featured-media{transform:scale(1.02)}
.bl-featured-body{display:flex;align-items:center;padding:clamp(48px,6vw,80px) clamp(32px,5vw,72px)}
.bl-featured-inner{max-width:520px}
.bl-featured-flag{display:flex;align-items:center;gap:14px;font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.28em;color:#1B3A6B;margin:0 0 28px;text-transform:uppercase}
.bl-featured-flag-line{display:inline-block;width:48px;height:1px;background:#1B3A6B}
.bl-featured-cat{font-family:'Noto Serif JP',serif;font-weight:700;font-size:12px;color:#1B3A6B;margin:0 0 16px;letter-spacing:.05em}
.bl-featured-title{font-family:'Noto Serif JP',serif;font-weight:700;font-size:clamp(24px,2.8vw,38px);line-height:1.4;letter-spacing:.01em;color:#1A1A1A;margin:0 0 24px;transition:color .3s}
.bl-featured-link:hover .bl-featured-title{color:#1B3A6B}
.bl-featured-excerpt{font-size:15px;color:#555;line-height:2;margin:0 0 32px}
.bl-featured-meta{display:flex;align-items:center;gap:14px;font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.12em;color:#999;font-variant-numeric:tabular-nums;margin-bottom:40px}
.bl-featured-cta{display:inline-flex;align-items:center;gap:14px;font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.22em;color:#1A1A1A;padding-bottom:8px;border-bottom:1px solid #1A1A1A;transition:all .3s}
.bl-featured-link:hover .bl-featured-cta{color:#1B3A6B;border-bottom-color:#1B3A6B}
.bl-featured-link:hover .bl-featured-cta .bl-arrow{transform:translateX(6px)}
@media (max-width:900px){
.bl-featured-link{grid-template-columns:1fr;min-height:auto}
.bl-featured-media{aspect-ratio:16/10}
.bl-featured-body{padding:40px 24px 56px}
.bl-featured-inner{max-width:none}
}

/* LIST */
.bl-list{padding:clamp(72px,10vw,140px) 0}
.bl-list-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(48px,6vw,72px);padding-bottom:28px;border-bottom:1px solid #E5E5E5}
.bl-list-eyebrow{font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.28em;color:#1B3A6B;margin:0 0 12px;text-transform:uppercase}
.bl-list-title{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(32px,4vw,56px);letter-spacing:.02em;color:#1A1A1A;margin:0;line-height:1}
.bl-list-count{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(28px,3vw,40px);color:#1A1A1A;margin:0;letter-spacing:.02em;font-variant-numeric:tabular-nums;white-space:nowrap}
.bl-list-count span{font-size:11px;font-weight:700;letter-spacing:.2em;color:#999;margin-left:10px}

.bl-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(56px,6vw,80px) clamp(24px,3vw,36px)}
@media (min-width:1480px){.bl-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:960px){.bl-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:56px 20px}}
@media (max-width:560px){.bl-grid{grid-template-columns:1fr;gap:56px}}

.bl-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;position:relative}
.bl-card-media{position:relative;aspect-ratio:5/3;background-size:cover;background-position:center;background-color:#F0F0F0;overflow:hidden;margin-bottom:22px;transition:transform .8s cubic-bezier(.2,.6,.2,1)}
.bl-card:hover .bl-card-media{transform:scale(1.02)}
.bl-card-media.is-placeholder{background:linear-gradient(135deg,#F0F0F0 0%,#E5E5E5 100%)}
.bl-card-chip{position:absolute;top:16px;left:16px;display:inline-block;padding:6px 12px;background:rgba(255,255,255,.95);font-family:'Noto Serif JP',serif;font-weight:700;font-size:11px;color:#1B3A6B;letter-spacing:.05em;z-index:2}
.bl-card-body{display:flex;flex-direction:column;gap:14px;padding:0 2px}
.bl-card-title{font-family:'Noto Serif JP',serif;font-weight:700;font-size:clamp(16px,1.3vw,19px);line-height:1.65;letter-spacing:.015em;color:#1A1A1A;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;transition:color .25s}
.bl-card:hover .bl-card-title{color:#1B3A6B}
.bl-card-meta{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.14em;color:#999;font-variant-numeric:tabular-nums}
@media (max-width:560px){
.bl-card-media{aspect-ratio:3/2;margin-left:-20px;margin-right:-20px;margin-bottom:20px}
.bl-card-body{padding:0}
.bl-card-title{font-size:18px;line-height:1.6}
.bl-card-chip{top:14px;left:14px}
}

/* EMPTY */
.bl-empty{text-align:center;padding:clamp(60px,10vw,120px) 20px;border:1px solid #E5E5E5}
.bl-empty-eyebrow{font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.28em;color:#999;margin:0 0 20px}
.bl-empty-title{font-family:'Noto Serif JP',serif;font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.7;color:#1A1A1A;margin:0 0 32px}
.bl-empty-link{display:inline-block;font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.22em;color:#1B3A6B;padding-bottom:6px;border-bottom:1px solid #1B3A6B;transition:letter-spacing .3s}
.bl-empty-link:hover{letter-spacing:.3em}

/* PAGINATION */
.bl-pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin-top:clamp(64px,8vw,96px);padding-top:48px;border-top:1px solid #E5E5E5}
.bl-pagination a,.bl-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:48px;height:48px;padding:0 10px;font-family:'Playfair Display',serif;font-weight:700;font-size:14px;color:#999;transition:all .2s;font-variant-numeric:tabular-nums;letter-spacing:.06em}
.bl-pagination a:hover{color:#1B3A6B}
.bl-pagination span.is-current{color:#FFF;background:#1B3A6B}
.bl-pagination .bl-pg-nav{font-size:11px;letter-spacing:.22em;color:#1A1A1A;padding:0 20px}
.bl-pagination .bl-pg-nav:hover{color:#1B3A6B}
.bl-pagination .is-off{color:#DDD;pointer-events:none}

/* CTA */
.bl-cta{background:#0F192D;color:#FFF;padding:clamp(80px,12vw,140px) 40px;text-align:center;position:relative;overflow:hidden}
.bl-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(27,58,107,.4) 0%,transparent 70%);pointer-events:none}
.bl-cta-inner{position:relative;max-width:720px;margin:0 auto}
.bl-cta-eyebrow{font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.35em;color:rgba(255,255,255,.65);margin:0 0 28px;text-transform:uppercase}
.bl-cta-title{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(36px,5vw,64px);letter-spacing:.02em;color:#FFF;margin:0 0 24px;line-height:1.05}
.bl-cta-sub{font-family:'Noto Serif JP',serif;font-weight:500;font-size:clamp(14px,1.3vw,16px);color:rgba(255,255,255,.8);line-height:2;margin:0 auto 44px}
.bl-cta-btn{display:inline-flex;align-items:center;gap:14px;padding:20px 52px;background:#FFF;color:#0F192D;font-family:'Playfair Display',serif;font-weight:700;font-size:12px;letter-spacing:.22em;transition:all .3s}
.bl-cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.3)}
.bl-cta-btn:hover .bl-arrow{transform:translateX(6px)}
@media (max-width:560px){
.bl-cta{padding:80px 24px}
.bl-cta-btn{padding:18px 40px;font-size:11px;width:100%;max-width:320px}
}
