*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#F8F4E6;--text:#0A0B09;--sub:rgba(10,11,9,.72);--border:rgba(10,11,9,.14);
  --card:rgba(255,255,255,.62);--gold:#B88B4A;--gold-h:#A57A3A;--dark:#0A0B09;
  --font:"Noto Serif JP","Hiragino Mincho ProN","YuMincho",serif;
  --en:"Inter",sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.8;letter-spacing:.04em;font-weight:500;-webkit-font-smoothing:antialiased;position:relative}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:
  radial-gradient(ellipse 80% 60% at 20% 10%, rgba(184,139,74,.06), transparent),
  radial-gradient(ellipse 60% 80% at 85% 80%, rgba(184,139,74,.05), transparent),
  radial-gradient(ellipse 50% 50% at 50% 50%, rgba(255,255,255,.15), transparent)}
body>*{position:relative;z-index:1}

@keyframes steam-drift{0%{transform:translateY(0) scale(1);opacity:.04}50%{opacity:.07}100%{transform:translateY(-120px) scale(1.3);opacity:0}}
.steam{position:fixed;pointer-events:none;z-index:0}
.steam i{position:absolute;background:radial-gradient(circle,rgba(184,139,74,.08),transparent 70%);border-radius:50%;animation:steam-drift 8s ease-in-out infinite}
.steam i:nth-child(1){width:300px;height:300px;left:5%;top:60%;animation-delay:0s;animation-duration:10s}
.steam i:nth-child(2){width:200px;height:200px;right:10%;top:30%;animation-delay:3s;animation-duration:12s}
.steam i:nth-child(3){width:250px;height:250px;left:40%;top:70%;animation-delay:5s;animation-duration:9s}

.scroll-bar{position:fixed;top:0;left:0;height:2px;background:var(--gold);z-index:200;width:0%;pointer-events:none;transform-origin:left;transition:width .08s linear}

@keyframes fog-l{0%{transform:translateX(-8%);opacity:0}20%{opacity:1}80%{opacity:.7}100%{transform:translateX(7%);opacity:0}}
@keyframes fog-r{0%{transform:translateX(7%);opacity:0}25%{opacity:1}75%{opacity:.6}100%{transform:translateX(-8%);opacity:0}}
@keyframes fog-rise{0%{transform:translateY(0) scaleX(1);opacity:0}35%{opacity:1}65%{opacity:.8}100%{transform:translateY(-28px) scaleX(1.04);opacity:0}}
.hero-fog{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.hero-fog b{position:absolute;left:-10%;width:120%;border-radius:50%;filter:blur(52px)}
.hero-fog b:nth-child(1){height:180px;bottom:20%;background:rgba(255,252,238,.09);animation:fog-l 26s ease-in-out infinite}
.hero-fog b:nth-child(2){height:110px;bottom:42%;background:rgba(255,252,238,.06);animation:fog-r 32s ease-in-out infinite 9s}
.hero-fog b:nth-child(3){height:240px;bottom:3%;background:rgba(255,252,238,.11);animation:fog-rise 21s ease-in-out infinite 4s}
.hero-fog b:nth-child(4){height:85px;bottom:60%;background:rgba(255,252,238,.05);animation:fog-l 38s ease-in-out infinite 15s}

@keyframes hero-in{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.hero-date{animation:hero-in 1.2s cubic-bezier(.2,1,.3,1) .35s both}
.hero-title{animation:hero-in 1.4s cubic-bezier(.2,1,.3,1) .65s both}
.hero-rule{animation:hero-in 1s ease .92s both}
.hero-sub{animation:hero-in 1s ease 1.08s both}

.facility-img{overflow:hidden}
.facility-img img{transition:transform 7s cubic-bezier(.2,1,.3,1)}
.facility-img:hover img{transform:scale(1.06)}

.divider-img{position:relative}
.divider-img::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 70% 50% at 50% 85%,rgba(255,252,238,.18),transparent);
  animation:fog-rise 8s ease-in-out infinite}
.divider-img::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(0deg,rgba(248,244,230,.28) 0%,transparent 35%,transparent 65%,rgba(248,244,230,.22) 100%)}

@keyframes reveal-up{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.2,1,.3,1),transform .8s cubic-bezier(.2,1,.3,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
a{color:var(--gold);text-decoration:none}
img{max-width:100%;display:block}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}

/* Header */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(248,244,230,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background .4s}
.header-inner{max-width:1400px;margin:0 auto;padding:0 40px;height:80px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center}
.logo img{height:28px;width:auto;display:block}
.nav{display:flex;gap:36px;list-style:none}
.nav a{font-size:.8rem;font-weight:500;color:var(--sub);letter-spacing:.14em;transition:color .3s}
.nav a:hover{color:var(--gold)}
.header-cta{font-size:.8rem;font-weight:500;letter-spacing:.12em;background:var(--gold);color:var(--bg);padding:10px 24px;border-radius:0;transition:background .3s}
.header-cta:hover{background:var(--gold-h);color:var(--bg)}

/* Hero */
.hero{height:100vh;min-height:600px;display:flex;align-items:flex-end;justify-content:center;text-align:center;position:relative;background:#0e0c0a center 20%/cover no-repeat;padding-bottom:14vh}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,9,8,.08) 0%,rgba(10,9,8,.3) 45%,rgba(10,9,8,.82) 100%)}
.hero-content{position:relative;z-index:3;color:var(--bg);width:100%;max-width:900px;padding:0 24px}
.hero-date{font-family:var(--en);font-size:.72rem;font-weight:400;letter-spacing:.55em;margin-bottom:28px;opacity:.7;display:flex;align-items:center;justify-content:center;gap:18px}
.hero-date::before,.hero-date::after{content:"";display:block;width:36px;height:1px;background:var(--gold);opacity:.7}
.hero-title{margin-bottom:28px;line-height:1}
.hero-title img{height:clamp(48px,7vw,90px);width:auto;filter:none;opacity:.97}
.hero-rule{width:32px;height:1px;background:var(--gold);opacity:.5;margin:0 auto 24px}
.hero-sub{font-size:1rem;font-weight:400;letter-spacing:.18em;opacity:.8;line-height:2.5}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;color:var(--bg);opacity:.35;font-family:var(--en);font-size:.62rem;letter-spacing:.25em;text-align:center}
.hero-scroll::after{content:"";display:block;width:1px;height:32px;background:var(--bg);margin:8px auto 0;opacity:.5}

/* Sections */
.section{padding:96px 24px}
.section-inner{max-width:1100px;margin:0 auto}

/* Full-width divider */
.divider-img{height:50vh;min-height:360px;background:#3a3530 center/cover no-repeat;position:relative}
.divider-img.d1{background-image:url('../images/bath.jpg')}
.divider-img.d2{background-image:url('../images/sauna.jpg')}
.divider-img.d3{background-image:url('../images/tenmusu02.jpg')}

/* Facility */
.facility-item{display:flex;gap:48px;align-items:center;margin-bottom:80px}
.facility-item:last-child{margin-bottom:0}
.facility-item.reverse{flex-direction:row-reverse}
.facility-img{flex:1.4;aspect-ratio:3/2;background:#3a3530;border-radius:0;overflow:hidden;position:relative}
.facility-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,1,.3,1)}
.facility-img:hover img{transform:scale(1.03)}
.facility-slider .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;will-change:opacity}
.facility-slider .slide.is-active{opacity:1}
.facility-slider:hover .slide.is-active{transform:scale(1.03)}
.slider-dots{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:8px;z-index:3;pointer-events:none}
.slider-dots .dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.38);transition:background .3s,transform .3s;cursor:pointer;pointer-events:auto}
.slider-dots .dot.is-active{background:rgba(255,255,255,.95);transform:scale(1.15)}
.facility-text{flex:1}
.facility-en{font-family:var(--en);font-size:.8rem;font-weight:500;letter-spacing:.2em;color:var(--gold);margin-bottom:8px;text-transform:uppercase}
.facility-title{font-size:1.1rem;font-weight:500;letter-spacing:.06em;margin-bottom:12px}
.facility-desc{font-size:.95rem;color:var(--sub);line-height:2;font-weight:500}

/* Hours */
.hours{text-align:center}
.hours h2{font-size:1.1rem;font-weight:500;letter-spacing:.1em;margin-bottom:32px;color:var(--gold)}
.hours-list{font-size:.92rem;line-height:2.4;display:inline-block;text-align:left}
.hours-row{display:flex;gap:1.5em;justify-content:center}
.hours-row dt{min-width:5em;text-align:right;font-weight:500}
.hours-row dd{text-align:left}
.hours-note{font-size:.8rem;color:var(--sub);margin-top:16px}

/* Price */
.price{text-align:center}
.price h2{font-size:1.1rem;font-weight:500;letter-spacing:.1em;margin-bottom:32px;color:var(--gold)}
.price-table{width:100%;max-width:720px;margin:0 auto;border-collapse:collapse}
.price-table th,.price-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:.95rem;font-weight:500}
.price-table thead th{font-weight:600;color:var(--sub);letter-spacing:.06em;font-size:.85rem}
.price-val{font-family:var(--en);font-weight:500;color:var(--gold);letter-spacing:.02em}

/* Brand */
.brand{text-align:center}
.brand-label{font-family:var(--en);font-size:.7rem;letter-spacing:.2em;color:var(--gold);margin-bottom:8px;text-transform:uppercase}
.brand h2{font-size:1.3rem;font-weight:500;letter-spacing:.08em;margin-bottom:16px}
.brand p{font-size:.88rem;color:var(--sub);max-width:560px;margin:0 auto 24px;line-height:2}
.btn-outline{display:inline-block;font-size:.78rem;letter-spacing:.08em;border:1px solid var(--gold);color:var(--gold);padding:10px 28px;border-radius:0;transition:all .3s}
.btn-outline:hover{background:var(--gold);color:var(--bg)}

/* Meshi */
.meshi{display:flex;gap:48px;align-items:center}
.meshi-img{flex:1.2;aspect-ratio:4/3;background:#2a2520;overflow:hidden}
.meshi-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,1,.3,1)}
.meshi-img:hover img{transform:scale(1.03)}
.meshi-text{flex:1}
.meshi-text h2{font-size:1.1rem;font-weight:500;letter-spacing:.06em;margin-bottom:12px}
.meshi-text p{font-size:.88rem;color:var(--sub);line-height:2;margin-bottom:16px}

/* Access */
.access{display:flex;gap:64px}
.access-map{flex:1.4;aspect-ratio:3/2;background:#e8e4d6;display:flex;align-items:center;justify-content:center;color:var(--sub);font-size:.75rem;letter-spacing:.1em}
.access-info{flex:1}
.access-info h2{font-size:.95rem;font-weight:400;letter-spacing:.18em;margin-bottom:28px;color:var(--gold)}
.access-info dl{font-size:.85rem;line-height:2;font-weight:500}
.access-info dt{color:var(--sub);font-size:.8rem;margin-top:16px;letter-spacing:.12em;font-weight:600}
.access-info dt:first-child{margin-top:0}
.access-info dd{padding-bottom:16px;border-bottom:1px solid var(--border)}

/* LINE CTA */
.line-cta{text-align:center;padding:120px 40px;background:var(--gold)}
.line-cta h2{font-size:1rem;font-weight:400;letter-spacing:.14em;color:var(--bg);margin-bottom:12px}
.line-cta p{font-size:.78rem;color:rgba(248,244,230,.85);margin-bottom:36px;font-weight:500;letter-spacing:.08em}
.btn-light{display:inline-block;background:var(--bg);color:var(--gold-h);font-size:.75rem;font-weight:400;padding:14px 40px;border-radius:0;letter-spacing:.14em;transition:all .3s}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12);color:var(--gold-h)}

/* Footer */
.footer{background:var(--dark);color:rgba(248,244,230,.4);padding:64px 40px 32px}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:48px}
.footer-logo{font-size:.85rem;font-weight:400;letter-spacing:.16em;color:var(--gold)}
.footer-links{display:flex;gap:28px;list-style:none}
.footer-links a{font-size:.82rem;font-weight:500;color:rgba(248,244,230,.65);letter-spacing:.1em;transition:color .3s}
.footer-links a:hover{color:var(--gold)}
.footer-social{display:flex;gap:16px}
.footer-social a{width:40px;height:40px;border:1px solid rgba(248,244,230,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(248,244,230,.45);transition:all .3s}
.footer-social svg{display:block;flex-shrink:0}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}
.footer-copy{font-family:var(--en);font-size:.78rem;font-weight:400;letter-spacing:.1em;text-align:center;padding-top:28px;border-top:1px solid rgba(248,244,230,.06)}

/* Hamburger */
.menu-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:0 8px;z-index:201}
.menu-btn span{display:block;width:24px;height:1.5px;background:var(--dark);transition:transform .35s cubic-bezier(.2,1,.3,1),opacity .25s}
.menu-btn.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-btn.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Drawer */
.menu-drawer{position:fixed;inset:0;z-index:150;background:var(--bg);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:0;opacity:0;pointer-events:none;transition:opacity .4s cubic-bezier(.2,1,.3,1)}
.menu-drawer.open{opacity:1;pointer-events:auto}
.menu-drawer nav{text-align:center}
.menu-drawer nav ul{list-style:none;padding:0;margin:0 0 40px}
.menu-drawer nav li{border-bottom:1px solid var(--border)}
.menu-drawer nav a{display:block;font-size:1.1rem;font-weight:400;letter-spacing:.18em;color:var(--dark);padding:20px 60px;transition:color .2s}
.menu-drawer nav a:hover{color:var(--gold)}
.menu-drawer .drawer-cta{background:var(--gold);color:var(--bg);font-size:.85rem;font-weight:400;letter-spacing:.14em;padding:16px 48px;display:inline-block}

/* === MESHI FEATURE === */
.meshi-feature{position:relative;background:#0e0c08;overflow:hidden;min-height:50vh;display:flex;flex-direction:column;justify-content:center}
.meshi-feature-bg{position:absolute;inset:0}
.meshi-feature-img{width:100%;height:100%;object-fit:cover;display:block;opacity:.3}
.meshi-feature-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0e0c08 0%,rgba(14,12,8,.55) 35%,rgba(14,12,8,.55) 65%,#0e0c08 100%)}
.meshi-feature-body{position:relative;z-index:2;text-align:center;padding:140px 40px;color:var(--bg)}
.meshi-feature-en{font-family:var(--en);font-size:.82rem;font-weight:500;letter-spacing:.3em;color:var(--gold);margin-bottom:36px;text-transform:uppercase}
.meshi-feature-logo{height:60px;width:auto;display:block;margin:0 auto 40px;opacity:.95}
.meshi-feature-lead{font-size:1.15rem;font-weight:400;letter-spacing:.12em;opacity:.9;margin-bottom:36px;line-height:2}
.meshi-feature-rule{width:48px;height:1px;background:var(--gold);opacity:.5;margin:0 auto 56px}
.meshi-feature-sub{font-size:.95rem;font-weight:500;letter-spacing:.08em;opacity:.75;max-width:520px;margin:0 auto 40px;line-height:2.2}
.meshi-feature-cta{display:inline-block;font-size:.88rem;font-weight:500;letter-spacing:.14em;border:1px solid rgba(184,139,74,.5);color:var(--gold);padding:12px 36px;transition:all .3s}
.meshi-feature-cta:hover{background:var(--gold);color:#0e0c08;border-color:var(--gold)}

/* Our Brand */
.our-brand{background:var(--bg);text-align:center;padding:80px 40px;border-top:1px solid var(--border)}
.our-brand-label{font-family:var(--en);font-size:.68rem;font-weight:400;letter-spacing:.3em;color:var(--sub);margin-bottom:48px;text-transform:uppercase}
.our-brand-grid{display:flex;align-items:stretch;justify-content:center;gap:24px;max-width:1100px;margin:0 auto}
.brand-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:48px 28px;background:#fff;border-radius:6px;box-shadow:0 4px 24px rgba(0,0,0,.09),0 1px 4px rgba(0,0,0,.06);transition:transform .25s,box-shadow .25s;cursor:pointer;text-decoration:none}
.brand-item:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(0,0,0,.14),0 2px 8px rgba(0,0,0,.08)}
.brand-item-logo{width:100%;height:44px;object-fit:contain;display:block}
.brand-sep{display:none}

/* Hero dual logos */
.hero-logos{display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.hero-logos .hero-title{flex:1;display:flex;align-items:center;justify-content:flex-end;padding-right:clamp(14px,2.5vw,36px);margin-bottom:0}
.hero-logos .hero-title--sub{justify-content:flex-start;padding-right:0;padding-left:clamp(14px,2.5vw,36px)}
.hero-logo-sep{flex-shrink:0;width:1px;height:clamp(48px,7vw,90px);background:var(--bg);opacity:.3}
.hero-title--sub img{height:clamp(48px,7vw,90px);width:auto;filter:none;opacity:.97}

/* Mobile */
@media(max-width:768px){
  .menu-btn{display:flex}
  .header-cta{display:none}
  .nav{display:none}
  .header-inner{height:60px;padding:0 20px}
  .hero-logos{flex-direction:column;gap:0}
  .hero-logos .hero-title{flex:0 0 auto;justify-content:center;padding:0 0 12px}
  .hero-logos .hero-title--sub{justify-content:center;padding:12px 0 0}
  .hero-logo-sep{width:clamp(48px,20vw,80px);height:1px;flex-shrink:0}
  .hero-title img{height:clamp(36px,8vw,56px)}
  .hero-title--sub img{height:clamp(36px,8vw,56px)}
  .hero-sub{font-size:.88rem;letter-spacing:.12em}
  .hero-date{font-size:.65rem;letter-spacing:.3em}
  .section{padding:64px 20px}
  .section-inner{max-width:100%}
  .facility-item,.facility-item.reverse{flex-direction:column;gap:20px;margin-bottom:56px}
  .facility-img{aspect-ratio:4/3}
  .facility-text{padding:0 4px}
  .meshi{flex-direction:column;gap:20px}
  .meshi-img{aspect-ratio:4/3}
  .price-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .price-table{min-width:480px}
  .access{flex-direction:column;gap:24px}
  .access-map{aspect-ratio:4/3}
  .divider-img{height:38vh;min-height:200px}
  .hours-list{font-size:.9rem}
  .brand p{font-size:.85rem}
  .footer-top{flex-direction:column;gap:20px}
  .footer-links{flex-wrap:wrap;gap:16px}
  .footer{padding:48px 20px 24px}
  .line-cta{padding:80px 20px}
  .line-cta h2{font-size:.95rem}
  .meshi-feature-body{padding:80px 24px}
  .meshi-feature-logo{height:44px}
  .meshi-feature-lead{font-size:1rem}
  .our-brand{padding:56px 0}
  .our-brand-label{padding:0 20px}
  .our-brand-grid{flex-direction:row;align-items:stretch;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:16px;max-width:100%;padding:8px 20px 20px;margin:0;justify-content:flex-start}
  .our-brand-grid::-webkit-scrollbar{display:none}
  .brand-item{flex:0 0 72vw;max-width:280px;scroll-snap-align:center;padding:36px 24px}
  .brand-item-logo{height:44px}
}

/* Accessibility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ===== Single article / Page / Archive (ブログ系) ===== */
body.single-body,body.page-body,body.archive-body{padding-top:80px}
.single-main,.page-main{max-width:880px;margin:0 auto;padding:64px 24px 96px}
.single-article{background:#fff;border:1px solid var(--border);border-radius:0;padding:56px 56px 64px;box-shadow:0 4px 24px rgba(10,11,9,.04)}
.single-header{margin-bottom:40px}
.single-breadcrumb{font-family:var(--en);font-size:.72rem;letter-spacing:.12em;color:var(--sub);margin-bottom:24px;display:flex;flex-wrap:wrap;gap:.4em;align-items:center}
.single-breadcrumb a{color:var(--sub);transition:color .3s}
.single-breadcrumb a:hover{color:var(--gold)}
.single-breadcrumb span{color:rgba(10,11,9,.3)}
.single-title{font-family:var(--font);font-size:1.7rem;font-weight:500;line-height:1.55;letter-spacing:.04em;color:var(--text);margin-bottom:20px}
.single-meta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:.78rem;color:var(--sub);font-family:var(--en);letter-spacing:.08em;padding-bottom:24px;border-bottom:1px solid var(--border)}
.single-meta time{font-family:var(--en)}
.single-meta .single-cat a{color:var(--gold);font-family:var(--font);letter-spacing:.06em;margin-right:.4em}
.single-meta .single-cat a:hover{color:var(--gold-h)}
.single-thumb{margin:32px -56px;overflow:hidden}
.single-thumb img{width:100%;height:auto;display:block}
.single-content{font-size:1rem;line-height:2.05;color:var(--text);font-weight:500}
.single-content p{margin:0 0 1.4em}
.single-content h2{font-family:var(--font);font-size:1.35rem;font-weight:600;letter-spacing:.06em;color:var(--text);margin:64px 0 20px;padding:18px 0 12px;border-top:1px solid var(--gold);position:relative}
.single-content h2::before{content:"";position:absolute;left:0;top:-1px;width:48px;height:1px;background:var(--gold);transform:translateY(-1px)}
.single-content h3{font-family:var(--font);font-size:1.08rem;font-weight:600;letter-spacing:.05em;color:var(--text);margin:36px 0 14px;padding-left:14px;border-left:3px solid var(--gold)}
.single-content h4{font-size:1rem;font-weight:600;margin:24px 0 10px;color:var(--gold-h)}
.single-content a{color:var(--gold);text-decoration:underline;text-underline-offset:.2em;text-decoration-thickness:1px;transition:color .3s}
.single-content a:hover{color:var(--gold-h)}
.single-content strong{font-weight:700;color:var(--text);background:linear-gradient(transparent 65%,rgba(184,139,74,.18) 65%)}
.single-content ul,.single-content ol{margin:0 0 1.6em;padding-left:1.6em}
.single-content ul li,.single-content ol li{margin-bottom:.5em}
.single-content ul li{list-style:none;position:relative;padding-left:1.1em}
.single-content ul li::before{content:"";position:absolute;left:0;top:.85em;width:.6em;height:1px;background:var(--gold)}
.single-content ol{list-style:decimal}
.single-content ol li{padding-left:.3em}
.single-content table{width:100%;border-collapse:collapse;margin:0 0 1.8em;font-size:.92rem;background:#fff;border:1px solid var(--border)}
.single-content thead th{background:rgba(184,139,74,.08);color:var(--text);font-weight:600;padding:14px 16px;text-align:left;border-bottom:2px solid var(--gold);letter-spacing:.04em}
.single-content tbody td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:top}
.single-content tbody tr:last-child td{border-bottom:none}
.single-content tbody tr:nth-child(even){background:rgba(248,244,230,.4)}
.single-content blockquote{margin:1.6em 0;padding:20px 24px;background:rgba(184,139,74,.05);border-left:3px solid var(--gold);font-style:italic;color:var(--sub)}
.single-content code{background:rgba(10,11,9,.06);padding:2px 6px;border-radius:2px;font-size:.92em;font-family:Menlo,Consolas,monospace}
.single-content hr{border:none;border-top:1px solid var(--border);margin:48px 0}
.single-footer{margin-top:56px;padding-top:32px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:20px}
.single-cat-links{font-size:.85rem;color:var(--sub);letter-spacing:.06em}
.single-cat-links a{display:inline-block;margin-left:.5em;padding:4px 12px;background:rgba(184,139,74,.08);color:var(--gold-h);border-radius:0;font-size:.82rem;transition:all .3s}
.single-cat-links a:hover{background:var(--gold);color:var(--bg)}
.single-back{display:inline-block;font-size:.84rem;letter-spacing:.1em;color:var(--gold);font-family:var(--font);transition:color .3s}
.single-back:hover{color:var(--gold-h)}

/* Page header (固定ページ・コラム一覧・アーカイブ共通) */
.page-header{text-align:center;padding:0 24px 48px;margin-bottom:48px;border-bottom:1px solid var(--border)}
.page-eyebrow{font-family:var(--en);font-size:.72rem;letter-spacing:.3em;color:var(--gold);margin-bottom:14px;text-transform:uppercase}
.page-title{font-family:var(--font);font-size:2rem;font-weight:500;letter-spacing:.08em;color:var(--text);margin:0 0 16px}
.page-lead{font-size:.92rem;color:var(--sub);line-height:2;max-width:560px;margin:0 auto;font-weight:500}
.page-article{font-size:1rem;line-height:2.05;color:var(--text)}

/* Post grid (コラム一覧・アーカイブ) — 3列固定（タブレット2列／モバイル1列） */
.post-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:32px;margin-top:24px}
.post-card{background:#fff;border:1px solid var(--border);transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(10,11,9,.08)}
.post-card-link{display:flex;flex-direction:column;height:100%;color:var(--text);text-decoration:none}
.post-card-thumb{aspect-ratio:16/9;overflow:hidden;background:#3a3530}
.post-card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.2,1,.3,1)}
.post-card:hover .post-card-thumb img{transform:scale(1.05)}
.post-card-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-card-cat{font-family:var(--en);font-size:.68rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;font-weight:500}
.post-card-title{font-family:var(--font);font-size:1rem;font-weight:600;line-height:1.65;letter-spacing:.04em;color:var(--text);margin:0;flex:1}
.post-card-date{font-family:var(--en);font-size:.7rem;color:var(--sub);letter-spacing:.08em;margin-top:auto}

.archive-empty{text-align:center;padding:64px 24px;color:var(--sub)}

/* Pagination (コラム一覧・アーカイブ・検索結果) — ブランドトンマナで横並び */
.pagination{margin:56px auto 80px;display:flex;justify-content:center}
.pagination .nav-links{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;font-family:var(--en);font-size:.85rem;font-weight:500;letter-spacing:.06em;color:var(--text);background:#fff;border:1px solid var(--border);text-decoration:none;transition:all .25s}
.pagination .page-numbers:hover{color:var(--gold);border-color:var(--gold);background:#fff}
.pagination .page-numbers.current{color:#fff;background:var(--gold);border-color:var(--gold);font-weight:600}
.pagination .page-numbers.dots{background:transparent;border-color:transparent;color:var(--sub)}
.pagination .page-numbers.prev,.pagination .page-numbers.next{padding:0 18px;letter-spacing:.08em}

/* Mobile blog (記事ページのスマホ対応) */
@media(max-width:768px){
  body.single-body,body.page-body,body.archive-body{padding-top:60px}
  .single-main,.page-main{padding:40px 16px 64px}
  .single-article{padding:32px 20px 40px}
  .single-thumb{margin:24px -20px}
  .single-title{font-size:1.3rem}
  .single-content{font-size:.94rem;line-height:1.95}
  .single-content h2{font-size:1.18rem;margin:48px 0 16px}
  .single-content h3{font-size:1rem;margin:28px 0 12px}
  .page-header{padding:0 16px 32px}
  .page-title{font-size:1.5rem}
  .post-grid{grid-template-columns:1fr;gap:20px}
  .pagination{margin:40px auto 56px}
  .pagination .page-numbers{min-width:38px;height:38px;font-size:.8rem;padding:0 12px}
}
@media(min-width:769px) and (max-width:1024px){
  .post-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
}
