/*
Theme Name: Lightning Child
Theme URI: 
Template: lightning
Description: Netsu Housing custom design built on Lightning
Author: 
Tags: 
Version: 0.15.2
*/

/* ==============================================================
   1. Design Tokens
   ============================================================== */
:root {
  --nh-green: #2F5D4E;
  --nh-green-light: #5A8574;
  --nh-green-dark: #1F3F35;
  --nh-green-mist: #DCE5E0;
  --nh-beige: #F4EFE6;
  --nh-beige-deep: #E8DFCD;
  --nh-beige-soft: #FAF7F1;
  --nh-gold: #A88B5C;
  --nh-gold-light: #C4A77A;
  --nh-white: #FFFFFF;
  --nh-text: #2A2A2A;
  --nh-text-muted: #7A7A7A;
  --nh-text-subtle: #A8A39A;
  --nh-border: #E5E1D8;
  --nh-shadow-sm: 0 4px 16px rgba(31, 63, 53, 0.05);
  --nh-shadow-md: 0 12px 40px rgba(31, 63, 53, 0.07);
  --nh-shadow-lg: 0 24px 60px rgba(31, 63, 53, 0.10);
  --nh-radius-sm: 6px;
  --nh-radius-md: 12px;
  --nh-radius-lg: 20px;
  --nh-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --nh-container: 1200px;
}

/* ==============================================================
   2. Webfont application
   ============================================================== */
body { font-family: 'Noto Sans JP', 'Hiragino Sans', sans-serif; letter-spacing: 0.02em; -webkit-font-smoothing: antialiased; }
.site-header .navbar-brand, .site-header h1, .site-header h2 { font-family: 'Noto Serif JP', serif; }

/* ==============================================================
   3. Scoped styles (.nh-home wrapper applies to all custom pages)
   ============================================================== */
.nh-home { color: var(--nh-text); line-height: 1.8; }
.nh-home *, .nh-home *::before, .nh-home *::after { box-sizing: border-box; }
.nh-home h1, .nh-home h2, .nh-home h3, .nh-home h4 { margin: 0; font-family: 'Noto Serif JP', serif; letter-spacing: 0.04em; color: var(--nh-green-dark); }
.nh-home p { margin: 0; }
.nh-home a { color: inherit; text-decoration: none; transition: color 0.3s var(--nh-ease); }
.nh-home ul { list-style: none; padding: 0; margin: 0; }
.nh-home img { max-width: 100%; display: block; }

.nh-home .nh-container { max-width: var(--nh-container); margin: 0 auto; padding: 0 32px; }
.nh-home .nh-container-sm { max-width: 880px; margin: 0 auto; padding: 0 32px; }
.nh-home .nh-fullwidth { width: 100vw; position: relative; left: 50%; margin-left: -50vw; }

/* Section heading */
.nh-home .nh-section-label { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.95rem; letter-spacing: 0.18em; color: var(--nh-gold); margin-bottom: 14px; display: inline-block; }
.nh-home .nh-section-title { font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 600; line-height: 1.5; margin-bottom: 18px; }

/* Override Lightning theme's default heading decorations (blue border lines etc) */
.nh-home .nh-section-head h2,
.nh-home .nh-section-head h3,
.nh-home .nh-section-title,
.nh-home .nh-page-title,
.nh-home .nh-pillar-title,
.nh-home .nh-service-title,
.nh-home .nh-property-title,
.nh-home .nh-news-col-title,
.nh-home .nh-cta-title,
.nh-home .nh-lp-hero-title,
.nh-home .nh-hero-title { border: none !important; background: none !important; padding-top: 0 !important; padding-bottom: 0 !important; }
.nh-home .nh-section-head h2::before, .nh-home .nh-section-head h2::after,
.nh-home .nh-section-head h3::before, .nh-home .nh-section-head h3::after { content: none !important; border: none !important; background: none !important; }
.nh-home .nh-section-label { border: none !important; }
.nh-home .nh-section-label::after { content: none !important; }
.nh-home .nh-section-lead { color: var(--nh-text-muted); font-size: 0.95rem; max-width: 580px; line-height: 2; }
.nh-home .nh-section-head { margin-bottom: 64px; }
.nh-home .nh-section-head.center { text-align: center; }
.nh-home .nh-section-head.center .nh-section-lead { margin: 0 auto; }

/* Buttons */
.nh-home .nh-btn { display: inline-flex; align-items: center; gap: 12px; padding: 16px 32px; font-size: 0.9rem; font-weight: 500; letter-spacing: 0.08em; transition: all 0.3s var(--nh-ease); border-radius: var(--nh-radius-sm); border: none; cursor: pointer; text-decoration: none; }
.nh-home .nh-btn-primary { background: var(--nh-green); color: var(--nh-white); }
.nh-home .nh-btn-primary:hover { background: var(--nh-green-dark); color: var(--nh-white); transform: translateY(-2px); box-shadow: var(--nh-shadow-md); }
.nh-home .nh-btn-ghost { color: var(--nh-green-dark); border: 1px solid var(--nh-green); background: transparent; }
.nh-home .nh-btn-ghost:hover { background: var(--nh-green); color: var(--nh-white); }
.nh-home .nh-btn-gold { background: var(--nh-gold); color: var(--nh-white); }
.nh-home .nh-btn-gold:hover { background: #927544; color: var(--nh-white); transform: translateY(-2px); box-shadow: var(--nh-shadow-md); }
.nh-home .nh-btn-text { color: var(--nh-green-dark); font-size: 0.85rem; font-weight: 500; letter-spacing: 0.1em; display: inline-flex; align-items: center; gap: 8px; border-bottom: 1px solid transparent; padding-bottom: 4px; transition: all 0.3s var(--nh-ease); }
.nh-home .nh-btn-text::after { content: '→'; transition: transform 0.3s var(--nh-ease); }
.nh-home .nh-btn-text:hover { border-bottom-color: var(--nh-green); }
.nh-home .nh-btn-text:hover::after { transform: translateX(6px); }
.nh-home .nh-btn-large { padding: 22px 44px; font-size: 1rem; }

/* ==============================================================
   4. Homepage hero
   ============================================================== */
.nh-home .nh-hero { position: relative; min-height: 78vh; display: flex; align-items: center; background: linear-gradient(180deg, #FAF7F1 0%, #EFEAE0 100%); overflow: hidden; }
.nh-home .nh-hero .nh-container { max-width: none; width: 100%; padding-left: max(60px, 10vw); padding-right: 32px; margin: 0; }
.nh-home .nh-hero-grain { position: absolute; inset: 0; opacity: 0.4; pointer-events: none; background-image: radial-gradient(rgba(168, 139, 92, 0.08) 1px, transparent 1px); background-size: 6px 6px; }
.nh-home .nh-hero-photo { position: absolute; top: 0; right: 0; width: 48%; height: 100%; background: linear-gradient(135deg, #C9D2CB 0%, #A4B5A9 50%, #7E9486 100%); overflow: hidden; border-radius: var(--nh-radius-lg) 0 0 var(--nh-radius-lg); background-size: cover !important; background-position: center !important; }
.nh-home .nh-hero-photo:not([style*="background-image"])::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(180deg, transparent 60%, rgba(31, 63, 53, 0.25) 100%), url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 600'><g fill='%231F3F35' opacity='0.18'><rect x='40' y='420' width='80' height='180'/><rect x='130' y='380' width='60' height='220'/><rect x='200' y='400' width='90' height='200'/><rect x='300' y='350' width='70' height='250'/><rect x='380' y='400' width='100' height='200'/><rect x='490' y='370' width='80' height='230'/><rect x='580' y='410' width='70' height='190'/><rect x='660' y='380' width='110' height='220'/></g><g fill='%231F3F35' opacity='0.10'><rect x='0' y='480' width='800' height='120'/></g></svg>"); background-size: cover; background-position: center; }
.nh-home .nh-hero-photo[style*="background-image"]::before { content: none; }
.nh-home .nh-hero-photo-label { position: absolute; bottom: 24px; right: 28px; color: rgba(255, 255, 255, 0.85); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; letter-spacing: 0.15em; z-index: 1; }
.nh-home .nh-hero-photo-label::before { content: '◇ '; color: var(--nh-gold-light); }
.nh-home .nh-hero-content { position: relative; z-index: 2; padding: 100px 0; max-width: min(500px, 44%); margin: 0; text-align: left; }
.nh-home .nh-hero-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1rem; color: var(--nh-gold); letter-spacing: 0.2em; margin-bottom: 28px; display: flex; align-items: center; gap: 16px; justify-content: flex-start; }
.nh-home .nh-hero-eyebrow::before { content: ''; width: 40px; height: 1px; background: var(--nh-gold); }
.nh-home .nh-hero-title { font-size: clamp(1.8rem, 3.2vw, 2.7rem); font-weight: 600; line-height: 1.5; letter-spacing: 0.04em; margin-bottom: 32px; color: var(--nh-green-dark); text-align: left; }
.nh-home .nh-hero-title .accent { color: var(--nh-green); position: relative; display: inline-block; }
.nh-home .nh-hero-title .accent::after { content: ''; position: absolute; left: 0; right: 0; bottom: -4px; height: 8px; background: var(--nh-gold-light); opacity: 0.32; z-index: -1; border-radius: 4px; }
.nh-home .nh-hero-subtitle { font-size: 1rem; color: var(--nh-text-muted); line-height: 2.1; margin-bottom: 40px; max-width: 420px; text-align: left; }
.nh-home .nh-hero-actions { display: flex; gap: 16px; flex-wrap: wrap; justify-content: flex-start; }
.nh-home .nh-hero-meta { position: absolute; bottom: 32px; left: 32px; display: flex; gap: 24px; font-size: 0.75rem; color: var(--nh-text-muted); letter-spacing: 0.12em; z-index: 2; }
.nh-home .nh-hero-meta div::before { content: '— '; color: var(--nh-gold); }

/* ==============================================================
   5. Page header (sub-pages)
   ============================================================== */
.nh-home .nh-page-header { padding: 100px 0 80px; background: linear-gradient(180deg, #FAF7F1 0%, #F4EFE6 100%); position: relative; overflow: hidden; text-align: center; }
.nh-home .nh-page-header::before { content: ''; position: absolute; top: -100px; right: -100px; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, var(--nh-green-mist) 0%, transparent 70%); opacity: 0.5; }
.nh-home .nh-page-header::after { content: ''; position: absolute; bottom: -80px; left: -80px; width: 240px; height: 240px; border-radius: 50%; background: radial-gradient(circle, var(--nh-beige-deep) 0%, transparent 70%); opacity: 0.6; }
.nh-home .nh-page-header-inner { position: relative; }
.nh-home .nh-page-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1rem; color: var(--nh-gold); letter-spacing: 0.2em; margin-bottom: 16px; }
.nh-home .nh-page-title { font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 600; color: var(--nh-green-dark); letter-spacing: 0.06em; line-height: 1.5; margin-bottom: 20px; }
.nh-home .nh-page-lead { color: var(--nh-text-muted); font-size: 1rem; line-height: 2; max-width: 680px; margin: 0 auto; }
.nh-home .nh-breadcrumb { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-text-subtle); letter-spacing: 0.15em; margin-bottom: 32px; }
.nh-home .nh-breadcrumb a { color: var(--nh-gold); }
.nh-home .nh-breadcrumb a:hover { color: var(--nh-green); }
.nh-home .nh-breadcrumb span { margin: 0 12px; }

/* ==============================================================
   6. Homepage sections
   ============================================================== */

/* Purpose entry */
.nh-home .nh-purpose { padding: 110px 0 90px; background: var(--nh-white); }
.nh-home .nh-purpose-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.nh-home .nh-purpose-card { padding: 48px 36px; background: var(--nh-white); border: 1px solid var(--nh-border); border-radius: var(--nh-radius-md); transition: all 0.4s var(--nh-ease); position: relative; cursor: pointer; display: block; }
.nh-home .nh-purpose-card:hover { background: var(--nh-beige-soft); border-color: var(--nh-green-mist); transform: translateY(-6px); box-shadow: var(--nh-shadow-md); }
.nh-home .nh-purpose-card:hover .nh-purpose-icon { color: var(--nh-green); }
.nh-home .nh-purpose-icon { color: var(--nh-green-light); margin-bottom: 28px; transition: all 0.3s var(--nh-ease); }
.nh-home .nh-purpose-en { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-gold); letter-spacing: 0.15em; margin-bottom: 8px; }
.nh-home .nh-purpose-ja { font-size: 1.4rem; font-weight: 600; margin-bottom: 14px; letter-spacing: 0.05em; }
.nh-home .nh-purpose-desc { font-size: 0.85rem; color: var(--nh-text-muted); line-height: 1.9; margin-bottom: 24px; }
.nh-home .nh-purpose-arrow { color: var(--nh-green); font-size: 0.85rem; letter-spacing: 0.1em; }

/* Services */
.nh-home .nh-services { padding: 110px 0; background: var(--nh-beige-soft); position: relative; overflow: hidden; }
.nh-home .nh-services::before { content: ''; position: absolute; top: -120px; right: -120px; width: 480px; height: 480px; border-radius: 50%; background: radial-gradient(circle, var(--nh-green-mist) 0%, transparent 70%); opacity: 0.55; }
.nh-home .nh-services::after { content: ''; position: absolute; bottom: -100px; left: -100px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, var(--nh-beige-deep) 0%, transparent 70%); opacity: 0.5; }
.nh-home .nh-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; position: relative; }
.nh-home .nh-service-card { background: var(--nh-white); padding: 52px 40px; border-radius: var(--nh-radius-md); transition: all 0.4s var(--nh-ease); border: 1px solid transparent; position: relative; }
.nh-home .nh-service-card:hover { transform: translateY(-8px); box-shadow: var(--nh-shadow-lg); border-color: var(--nh-green-mist); }
.nh-home .nh-service-num { position: absolute; top: 28px; right: 32px; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-gold); letter-spacing: 0.2em; }
.nh-home .nh-service-icon { width: 68px; height: 68px; background: var(--nh-beige); border-radius: 50%; display: grid; place-items: center; color: var(--nh-green); margin-bottom: 28px; }
.nh-home .nh-service-title { font-size: 1.4rem; font-weight: 600; margin-bottom: 16px; letter-spacing: 0.04em; }
.nh-home .nh-service-desc { font-size: 0.88rem; color: var(--nh-text-muted); line-height: 2; margin-bottom: 28px; }

/* Properties */
.nh-home .nh-properties { padding: 110px 0; background: var(--nh-white); }
.nh-home .nh-properties-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 56px; flex-wrap: wrap; gap: 24px; }
.nh-home .nh-properties-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.nh-home .nh-properties-grid.list { grid-template-columns: 1fr; gap: 20px; }
.nh-home .nh-property-card { background: var(--nh-white); transition: all 0.4s var(--nh-ease); cursor: pointer; display: block; border-radius: var(--nh-radius-md); overflow: hidden; border: 1px solid var(--nh-border); }
.nh-home .nh-property-card:hover { box-shadow: var(--nh-shadow-md); border-color: var(--nh-green-mist); transform: translateY(-4px); }
.nh-home .nh-property-card:hover .nh-property-image { transform: scale(1.04); }
.nh-home .nh-property-card:hover .nh-property-title { color: var(--nh-green); }
.nh-home .nh-property-image-wrap { aspect-ratio: 4/3; overflow: hidden; background: var(--nh-beige-deep); position: relative; }
.nh-home .nh-property-image { width: 100%; height: 100%; background: linear-gradient(135deg, #BCC8C0 0%, #8FA398 50%, #6F8478 100%); transition: transform 0.6s var(--nh-ease); position: relative; }
.nh-home .nh-property-image::after { content: ''; position: absolute; inset: 0; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 300'><g fill='%231F3F35' opacity='0.2'><rect x='40' y='180' width='100' height='120'/><polygon points='40,180 90,140 140,180'/><rect x='160' y='200' width='80' height='100'/><polygon points='160,200 200,160 240,200'/><rect x='260' y='190' width='100' height='110'/><polygon points='260,190 310,150 360,190'/></g></svg>"); background-size: cover; background-position: center; }
.nh-home .nh-property-tag { position: absolute; top: 16px; left: 16px; background: var(--nh-green); color: var(--nh-white); padding: 5px 14px; font-size: 0.72rem; letter-spacing: 0.12em; font-weight: 500; z-index: 1; border-radius: var(--nh-radius-sm); }
.nh-home .nh-property-tag.new { background: var(--nh-gold); }
.nh-home .nh-property-tag.condition { background: var(--nh-green-dark); }
.nh-home .nh-property-body { padding: 24px; }
.nh-home .nh-property-meta { font-family: 'Cormorant Garamond', serif; font-size: 0.78rem; color: var(--nh-gold); letter-spacing: 0.15em; font-style: italic; margin-bottom: 8px; }
.nh-home .nh-property-title { font-size: 1.15rem; font-weight: 600; margin-bottom: 14px; letter-spacing: 0.04em; transition: color 0.3s var(--nh-ease); }
.nh-home .nh-property-price { font-family: 'Noto Serif JP', serif; font-size: 1.6rem; font-weight: 700; color: var(--nh-green); margin-bottom: 14px; letter-spacing: 0.02em; }
.nh-home .nh-property-price small { font-size: 0.85rem; font-weight: 400; color: var(--nh-text-muted); margin-left: 4px; }
.nh-home .nh-property-specs { display: flex; gap: 14px; flex-wrap: wrap; font-size: 0.8rem; color: var(--nh-text-muted); padding-top: 14px; border-top: 1px solid var(--nh-border); }
.nh-home .nh-property-specs span { position: relative; padding-right: 14px; }
.nh-home .nh-property-specs span:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 1px; height: 12px; background: var(--nh-border); }

/* Rentals CTA */
.nh-home .nh-rentals-cta { padding: 0 0 110px; background: var(--nh-white); }
.nh-home .nh-rentals-grid { display: grid; grid-template-columns: 5fr 6fr; gap: 0; background: var(--nh-beige); border-radius: var(--nh-radius-lg); overflow: hidden; align-items: stretch; }
.nh-home .nh-rentals-visual { position: relative; min-height: 360px; background: linear-gradient(135deg, #B8C4B0 0%, #889A7F 50%, #607358 100%); overflow: hidden; background-size: cover !important; background-position: center !important; }
.nh-home .nh-rentals-visual:not([style*="background-image"])::after { content: ''; position: absolute; inset: 0; background-image: linear-gradient(180deg, transparent 50%, rgba(31, 63, 53, 0.3) 100%), url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 450'><g fill='%231F3F35' opacity='0.2'><rect x='80' y='120' width='180' height='280'/><rect x='280' y='160' width='140' height='240'/><rect x='440' y='100' width='120' height='300'/></g><g fill='%23F4EFE6' opacity='0.4'><rect x='110' y='180' width='25' height='35'/><rect x='160' y='180' width='25' height='35'/><rect x='210' y='180' width='25' height='35'/><rect x='110' y='240' width='25' height='35'/><rect x='160' y='240' width='25' height='35'/><rect x='210' y='240' width='25' height='35'/></g></svg>"); background-size: cover; }
.nh-home .nh-rentals-visual[style*="background-image"]::after { content: none; }
.nh-home .nh-rentals-visual-label { position: absolute; bottom: 20px; left: 24px; color: rgba(255, 255, 255, 0.85); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; letter-spacing: 0.15em; z-index: 1; }
.nh-home .nh-rentals-content { padding: 64px 56px; display: flex; flex-direction: column; justify-content: center; }
.nh-home .nh-rentals-note { font-size: 0.78rem; color: var(--nh-text-subtle); letter-spacing: 0.1em; margin-top: 20px; }

/* Area */
.nh-home .nh-area { padding: 130px 0; background: var(--nh-green-dark); color: var(--nh-white); position: relative; overflow: hidden; }
.nh-home .nh-area::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 80%, rgba(168, 139, 92, 0.15) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(90, 133, 116, 0.2) 0%, transparent 50%); }
.nh-home .nh-area-grid { display: grid; grid-template-columns: 5fr 6fr; gap: 64px; align-items: center; position: relative; }
.nh-home .nh-area-content .nh-section-label { color: var(--nh-gold-light); }
.nh-home .nh-area-content .nh-section-title { color: var(--nh-white); }
.nh-home .nh-area-content .nh-section-lead { color: rgba(255, 255, 255, 0.78); }
.nh-home .nh-area-quote { font-family: 'Noto Serif JP', serif; font-size: 1.05rem; font-style: italic; color: rgba(255, 255, 255, 0.92); line-height: 2; padding: 32px 0; border-top: 1px solid rgba(255, 255, 255, 0.15); border-bottom: 1px solid rgba(255, 255, 255, 0.15); margin: 32px 0; letter-spacing: 0.06em; }
.nh-home .nh-area-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 32px; align-items: end; }
.nh-home .nh-area-stat-num { font-family: 'Cormorant Garamond', serif; font-size: 2.4rem; font-weight: 500; color: var(--nh-gold-light); letter-spacing: 0.05em; line-height: 1; margin-bottom: 10px; }
.nh-home .nh-area-stat-text { font-family: 'Noto Serif JP', serif; font-size: 1.05rem; font-weight: 500; color: var(--nh-gold-light); letter-spacing: 0.04em; line-height: 1.55; margin-bottom: 10px; min-height: 2.4rem; display: flex; align-items: flex-end; }
.nh-home .nh-area-stat-label { font-size: 0.78rem; color: rgba(255, 255, 255, 0.7); letter-spacing: 0.1em; line-height: 1.6; }
.nh-home .nh-area-stat-label small { display: block; font-size: 0.7rem; color: rgba(255, 255, 255, 0.5); margin-top: 4px; letter-spacing: 0.08em; }

/* Notice band (under hero) */
.nh-home .nh-notice { background: var(--nh-green-dark); color: rgba(255, 255, 255, 0.94); border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.nh-home .nh-notice-inner { display: flex; align-items: center; gap: 18px; padding: 14px 0; font-size: 0.88rem; line-height: 1.6; flex-wrap: wrap; }
.nh-home .nh-notice-label { background: var(--nh-gold); color: var(--nh-white); padding: 4px 14px; font-size: 0.72rem; letter-spacing: 0.12em; border-radius: 999px; font-weight: 500; flex-shrink: 0; }
.nh-home .nh-notice-text { flex: 1; min-width: 0; }
.nh-home .nh-notice-text a { color: var(--nh-gold-light); text-decoration: underline; text-underline-offset: 3px; }
.nh-home .nh-notice-text a:hover { color: var(--nh-white); }
.nh-home .nh-area-photo { position: relative; aspect-ratio: 4/3; border-radius: var(--nh-radius-lg); overflow: hidden; background: linear-gradient(135deg, #5A7268 0%, #3D544A 50%, #2A3D34 100%); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3); background-size: cover !important; background-position: center !important; }
.nh-home .nh-area-photo:not([style*="background-image"])::after { content: ''; position: absolute; inset: 0; background-image: linear-gradient(180deg, transparent 50%, rgba(31, 63, 53, 0.4) 100%), url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 600'><g fill='%23000' opacity='0.25'><rect x='40' y='380' width='80' height='220'/><rect x='130' y='340' width='60' height='260'/><rect x='200' y='360' width='90' height='240'/><rect x='300' y='310' width='70' height='290'/><rect x='380' y='360' width='100' height='240'/><rect x='490' y='330' width='80' height='270'/><rect x='580' y='370' width='70' height='230'/><rect x='660' y='340' width='110' height='260'/></g></svg>"); background-size: cover; }
.nh-home .nh-area-photo[style*="background-image"]::after { content: none; }
.nh-home .nh-area-photo-label { position: absolute; bottom: 24px; right: 28px; color: rgba(255, 255, 255, 0.85); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; letter-spacing: 0.15em; z-index: 1; }
.nh-home .nh-area-photo-label::before { content: '◇ '; color: var(--nh-gold-light); }

/* News & Blog */
.nh-home .nh-news { padding: 110px 0; background: var(--nh-white); }
.nh-home .nh-news-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }
.nh-home .nh-news-col-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 32px; padding-bottom: 18px; border-bottom: 1px solid var(--nh-border); }
.nh-home .nh-news-col-title { font-size: 1.5rem; font-weight: 600; letter-spacing: 0.05em; }
.nh-home .nh-news-col-title small { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-gold); margin-left: 12px; letter-spacing: 0.15em; font-weight: 400; }
.nh-home .nh-news-list-link { font-size: 0.8rem; color: var(--nh-green); letter-spacing: 0.1em; }
.nh-home .nh-news-item { display: block; padding: 22px 0; border-bottom: 1px solid var(--nh-border); transition: all 0.3s var(--nh-ease); }
.nh-home .nh-news-item:hover { padding-left: 8px; }
.nh-home .nh-news-item:hover .nh-news-title { color: var(--nh-green); }
.nh-home .nh-news-item-meta { display: flex; align-items: center; gap: 14px; margin-bottom: 8px; }
.nh-home .nh-news-date { font-family: 'Cormorant Garamond', serif; font-size: 0.85rem; color: var(--nh-gold); letter-spacing: 0.12em; }
.nh-home .nh-news-cat { font-size: 0.7rem; background: var(--nh-beige); color: var(--nh-green-dark); padding: 4px 12px; letter-spacing: 0.1em; font-weight: 500; border-radius: 20px; }
.nh-home .nh-news-cat.event { background: var(--nh-green-mist); }
.nh-home .nh-news-cat.column { background: #EFE6D0; color: var(--nh-gold); }
.nh-home .nh-news-title { font-size: 0.95rem; color: var(--nh-text); line-height: 1.7; transition: color 0.3s var(--nh-ease); }
.nh-home .nh-blog-item { display: grid; grid-template-columns: 96px 1fr; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--nh-border); transition: all 0.3s var(--nh-ease); align-items: center; }
.nh-home .nh-blog-item:hover { padding-left: 8px; }
.nh-home .nh-blog-item:hover .nh-news-title { color: var(--nh-green); }
.nh-home .nh-blog-thumb { aspect-ratio: 4/3; background: linear-gradient(135deg, var(--nh-beige-deep) 0%, var(--nh-green-mist) 100%); border-radius: var(--nh-radius-sm); position: relative; overflow: hidden; }
.nh-home .nh-blog-thumb::after { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.4), transparent 60%); }

/* Company teaser */
.nh-home .nh-company { padding: 0 0 110px; background: var(--nh-white); }
.nh-home .nh-company-grid { display: grid; grid-template-columns: 5fr 6fr; gap: 0; background: var(--nh-beige); border-radius: var(--nh-radius-lg); overflow: hidden; }
.nh-home .nh-company-image { aspect-ratio: 4/3; background: linear-gradient(135deg, #B4C0B6 0%, #88998C 100%); position: relative; background-size: cover !important; background-position: center !important; }
.nh-home .nh-company-image:not([style*="background-image"])::after { content: ''; position: absolute; inset: 0; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 450'><g fill='%231F3F35' opacity='0.25'><rect x='100' y='150' width='400' height='300'/><polygon points='100,150 300,80 500,150'/><rect x='150' y='250' width='80' height='100' fill='%23F4EFE6' opacity='0.5'/><rect x='270' y='250' width='80' height='100' fill='%23F4EFE6' opacity='0.5'/><rect x='390' y='250' width='80' height='100' fill='%23F4EFE6' opacity='0.5'/></g></svg>"); background-size: cover; }
.nh-home .nh-company-image[style*="background-image"]::after { content: none; }
.nh-home .nh-company-image-label { position: absolute; bottom: 16px; left: 20px; color: rgba(255, 255, 255, 0.85); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.8rem; letter-spacing: 0.15em; }
.nh-home .nh-company-content { padding: 64px 56px 72px; display: flex; flex-direction: column; justify-content: center; }
.nh-home .nh-company-content > .nh-btn,
.nh-home .nh-company-content > a.nh-btn-ghost,
.nh-home .nh-company-content > div:last-child { margin-top: 12px; }
.nh-home .nh-company-content > div:last-child .nh-btn { margin-top: 0; }
.nh-home .nh-company-quote { font-family: 'Noto Serif JP', serif; font-size: 1.45rem; font-weight: 600; color: var(--nh-green-dark); line-height: 1.85; margin-bottom: 24px; letter-spacing: 0.04em; }
.nh-home .nh-company-text { color: var(--nh-text-muted); line-height: 2.1; margin-bottom: 32px; font-size: 0.92rem; }

/* CTA */
.nh-home .nh-cta { background: var(--nh-green); color: var(--nh-white); padding: 90px 0; position: relative; overflow: hidden; }
.nh-home .nh-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 80% 50%, rgba(168, 139, 92, 0.2) 0%, transparent 60%); }
.nh-home .nh-cta-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; }
.nh-home .nh-cta-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.95rem; color: var(--nh-gold-light); letter-spacing: 0.18em; margin-bottom: 16px; }
.nh-home .nh-cta-title { font-size: 2rem; font-weight: 600; color: var(--nh-white); line-height: 1.6; letter-spacing: 0.05em; margin-bottom: 18px; }
.nh-home .nh-cta-desc { color: rgba(255, 255, 255, 0.82); font-size: 0.92rem; line-height: 2; }
.nh-home .nh-cta-actions { display: flex; flex-direction: column; gap: 24px; }
.nh-home .nh-cta-phone { background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.2); padding: 30px 36px; border-radius: var(--nh-radius-md); backdrop-filter: blur(8px); }
.nh-home .nh-cta-phone-label { font-size: 0.75rem; color: rgba(255, 255, 255, 0.7); letter-spacing: 0.15em; margin-bottom: 8px; }
.nh-home .nh-cta-phone-num { font-family: 'Cormorant Garamond', serif; font-size: 2.4rem; font-weight: 500; color: var(--nh-white); letter-spacing: 0.04em; line-height: 1; margin-bottom: 6px; }
.nh-home .nh-cta-phone-hours { font-size: 0.78rem; color: rgba(255, 255, 255, 0.7); letter-spacing: 0.1em; }
.nh-home .nh-cta-form-link { background: var(--nh-white); color: var(--nh-green-dark); padding: 24px 36px; border-radius: var(--nh-radius-md); display: flex; justify-content: space-between; align-items: center; transition: all 0.3s var(--nh-ease); }
.nh-home .nh-cta-form-link:hover { background: var(--nh-gold); color: var(--nh-white); transform: translateY(-3px); box-shadow: var(--nh-shadow-md); }
.nh-home .nh-cta-form-link strong { font-family: 'Noto Serif JP', serif; font-size: 1.1rem; font-weight: 600; letter-spacing: 0.05em; }
.nh-home .nh-cta-form-link span { font-size: 0.75rem; color: var(--nh-text-muted); display: block; letter-spacing: 0.1em; margin-top: 4px; }
.nh-home .nh-cta-form-link:hover span { color: rgba(255, 255, 255, 0.7); }

/* ==============================================================
   7. Sub-page components
   ============================================================== */

/* Generic content section */
.nh-home .nh-section { padding: 100px 0; background: var(--nh-white); }
.nh-home .nh-section-alt { padding: 100px 0; background: var(--nh-beige-soft); }
.nh-home .nh-section-dark { padding: 100px 0; background: var(--nh-green-dark); color: var(--nh-white); }

/* Content typography (for readable text blocks inside sections) */
.nh-home .nh-content h2 { font-size: 1.75rem; font-weight: 600; color: var(--nh-green-dark); margin-bottom: 24px; letter-spacing: 0.05em; line-height: 1.5; }
.nh-home .nh-content h3 { font-size: 1.3rem; font-weight: 600; color: var(--nh-green-dark); margin: 40px 0 16px; letter-spacing: 0.05em; line-height: 1.6; padding-left: 14px; border-left: 3px solid var(--nh-green); }
.nh-home .nh-content p { font-size: 0.95rem; line-height: 2.1; color: var(--nh-text); margin-bottom: 20px; }
.nh-home .nh-content p.lead { font-size: 1.05rem; color: var(--nh-text-muted); }
.nh-home .nh-content ul.bullet { padding-left: 0; margin-bottom: 24px; }
.nh-home .nh-content ul.bullet li { padding-left: 24px; position: relative; margin-bottom: 12px; line-height: 1.9; font-size: 0.95rem; }
.nh-home .nh-content ul.bullet li::before { content: '◇'; position: absolute; left: 0; top: 0; color: var(--nh-gold); font-size: 0.85rem; }

/* Steps (process) */
.nh-home .nh-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; counter-reset: step; }
.nh-home .nh-step { background: var(--nh-white); padding: 36px 28px; border-radius: var(--nh-radius-md); border: 1px solid var(--nh-border); position: relative; }
.nh-home .nh-step::before { counter-increment: step; content: 'STEP ' counter(step, decimal-leading-zero); display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-gold); letter-spacing: 0.2em; margin-bottom: 16px; }
.nh-home .nh-step h4 { font-size: 1.1rem; font-weight: 600; color: var(--nh-green-dark); margin-bottom: 12px; letter-spacing: 0.04em; }
.nh-home .nh-step p { font-size: 0.85rem; color: var(--nh-text-muted); line-height: 1.9; }

/* FAQ */
.nh-home .nh-faq { display: flex; flex-direction: column; gap: 14px; }
.nh-home .nh-faq-item { background: var(--nh-white); border: 1px solid var(--nh-border); border-radius: var(--nh-radius-md); overflow: hidden; transition: all 0.3s var(--nh-ease); }
.nh-home .nh-faq-item[open] { border-color: var(--nh-green-mist); box-shadow: var(--nh-shadow-sm); }
.nh-home .nh-faq-q { padding: 22px 28px 22px 64px; cursor: pointer; font-weight: 500; color: var(--nh-green-dark); font-size: 0.98rem; line-height: 1.6; position: relative; list-style: none; }
.nh-home .nh-faq-q::-webkit-details-marker { display: none; }
.nh-home .nh-faq-q::before { content: 'Q'; position: absolute; left: 24px; top: 22px; font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--nh-gold); font-size: 1.1rem; letter-spacing: 0.05em; }
.nh-home .nh-faq-q::after { content: '+'; position: absolute; right: 28px; top: 22px; color: var(--nh-green); font-size: 1.3rem; transition: transform 0.3s var(--nh-ease); }
.nh-home .nh-faq-item[open] .nh-faq-q::after { content: '−'; }
.nh-home .nh-faq-a { padding: 0 28px 24px 64px; color: var(--nh-text-muted); font-size: 0.92rem; line-height: 2; position: relative; }
.nh-home .nh-faq-a::before { content: 'A'; position: absolute; left: 24px; top: 0; font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--nh-green); font-size: 1.1rem; letter-spacing: 0.05em; }

/* Type grid (rental categories) */
.nh-home .nh-type-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.nh-home .nh-type-card { display: flex; flex-direction: column; padding: 40px 32px; background: var(--nh-white); border: 1px solid var(--nh-border); border-radius: var(--nh-radius-md); transition: all 0.4s var(--nh-ease); cursor: pointer; height: 100%; }
.nh-home .nh-type-card:hover { background: var(--nh-beige-soft); border-color: var(--nh-green-mist); transform: translateY(-6px); box-shadow: var(--nh-shadow-md); }
.nh-home .nh-type-icon { width: 56px; height: 56px; background: var(--nh-beige); border-radius: 50%; display: grid; place-items: center; color: var(--nh-green); margin-bottom: 24px; }
.nh-home .nh-type-card:hover .nh-type-icon { background: var(--nh-green-mist); }
.nh-home .nh-type-en { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.8rem; color: var(--nh-gold); letter-spacing: 0.15em; margin-bottom: 6px; }
.nh-home .nh-type-title { font-size: 1.25rem; font-weight: 600; color: var(--nh-green-dark); margin-bottom: 12px; letter-spacing: 0.05em; line-height: 1.5; }
.nh-home .nh-type-desc { font-size: 0.85rem; color: var(--nh-text-muted); line-height: 1.9; margin-bottom: 24px; flex: 1; }
.nh-home .nh-type-link { color: var(--nh-green); font-size: 0.85rem; font-weight: 500; letter-spacing: 0.1em; display: inline-flex; align-items: center; gap: 8px; }
.nh-home .nh-type-link::after { content: '→'; transition: transform 0.3s var(--nh-ease); }
.nh-home .nh-type-card:hover .nh-type-link::after { transform: translateX(6px); }

/* Info table (company info, etc) */
.nh-home .nh-table { width: 100%; border-collapse: collapse; }
.nh-home .nh-table th, .nh-home .nh-table td { padding: 22px 24px; text-align: left; border-bottom: 1px solid var(--nh-border); font-size: 0.92rem; line-height: 1.9; vertical-align: top; }
.nh-home .nh-table th { width: 220px; font-weight: 500; color: var(--nh-green-dark); background: var(--nh-beige-soft); letter-spacing: 0.05em; }
.nh-home .nh-table td { color: var(--nh-text); }

/* Form (Contact Form 7 wrapper) */
.nh-home .nh-form { display: flex; flex-direction: column; gap: 24px; }
.nh-home .nh-form-group { display: flex; flex-direction: column; gap: 10px; }
.nh-home .nh-form-label { font-size: 0.85rem; font-weight: 500; color: var(--nh-green-dark); letter-spacing: 0.06em; }
.nh-home .nh-form-label .required { color: #C2554F; font-size: 0.7rem; margin-left: 8px; padding: 2px 8px; background: #FBE9E7; border-radius: 3px; letter-spacing: 0.1em; }
.nh-home .nh-form-input,
.nh-home .nh-form input[type="text"],
.nh-home .nh-form input[type="email"],
.nh-home .nh-form input[type="tel"],
.nh-home .nh-form select,
.nh-home .nh-form textarea { width: 100%; padding: 14px 18px; border: 1px solid var(--nh-border); border-radius: var(--nh-radius-sm); font-family: inherit; font-size: 0.95rem; background: var(--nh-white); transition: border-color 0.3s var(--nh-ease); }
.nh-home .nh-form-input:focus,
.nh-home .nh-form input:focus,
.nh-home .nh-form select:focus,
.nh-home .nh-form textarea:focus { outline: none; border-color: var(--nh-green); }
.nh-home .nh-form textarea { min-height: 160px; resize: vertical; }
.nh-home .nh-form-submit { display: flex; justify-content: center; margin-top: 16px; }

/* Feature pillar (3-column with icon) */
.nh-home .nh-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.nh-home .nh-pillar { text-align: center; padding: 40px 28px; }
.nh-home .nh-pillar-icon { width: 72px; height: 72px; margin: 0 auto 24px; background: var(--nh-beige); border-radius: 50%; display: grid; place-items: center; color: var(--nh-green); }
.nh-home .nh-pillar-num { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.85rem; color: var(--nh-gold); letter-spacing: 0.2em; margin-bottom: 10px; }
.nh-home .nh-pillar-title { font-size: 1.2rem; font-weight: 600; color: var(--nh-green-dark); margin-bottom: 14px; letter-spacing: 0.04em; line-height: 1.6; }
.nh-home .nh-pillar-desc { font-size: 0.88rem; color: var(--nh-text-muted); line-height: 2; }

/* CTA banner (smaller variant) */
.nh-home .nh-cta-banner { padding: 70px 0; background: var(--nh-green); color: var(--nh-white); text-align: center; position: relative; overflow: hidden; }
.nh-home .nh-cta-banner::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 50% 100%, rgba(168, 139, 92, 0.2) 0%, transparent 60%); }
.nh-home .nh-cta-banner-inner { position: relative; }
.nh-home .nh-cta-banner h2 { font-size: 1.7rem; font-weight: 600; color: var(--nh-white); margin-bottom: 14px; letter-spacing: 0.05em; line-height: 1.6; }
.nh-home .nh-cta-banner p { color: rgba(255, 255, 255, 0.85); font-size: 0.92rem; margin-bottom: 32px; line-height: 1.9; }
.nh-home .nh-cta-banner .nh-btn-ghost { color: var(--nh-white); border-color: rgba(255, 255, 255, 0.4); }
.nh-home .nh-cta-banner .nh-btn-ghost:hover { background: var(--nh-white); color: var(--nh-green-dark); border-color: var(--nh-white); }

/* Hero variant for LP */
.nh-home .nh-lp-hero { padding: 100px 0 80px; background: linear-gradient(135deg, #FAF7F1 0%, #EFEAE0 60%, #DCE5E0 100%); position: relative; overflow: hidden; }
.nh-home .nh-lp-hero::before { content: ''; position: absolute; top: -150px; right: -150px; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(168, 139, 92, 0.15) 0%, transparent 70%); }
.nh-home .nh-lp-hero::after { content: ''; position: absolute; bottom: -100px; left: -100px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, var(--nh-green-mist) 0%, transparent 70%); opacity: 0.5; }
.nh-home .nh-lp-hero-inner { position: relative; text-align: center; max-width: 820px; margin: 0 auto; }
.nh-home .nh-lp-hero-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1rem; color: var(--nh-gold); letter-spacing: 0.2em; margin-bottom: 24px; }
.nh-home .nh-lp-hero-title { font-size: clamp(2rem, 4.5vw, 3rem); font-weight: 600; color: var(--nh-green-dark); line-height: 1.5; letter-spacing: 0.06em; margin-bottom: 28px; }
.nh-home .nh-lp-hero-title .accent { color: var(--nh-green); }
.nh-home .nh-lp-hero-sub { font-size: 1.05rem; color: var(--nh-text-muted); line-height: 2; margin-bottom: 40px; }
.nh-home .nh-lp-hero-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Image placeholder */
.nh-home .nh-img-ph { aspect-ratio: 4/3; border-radius: var(--nh-radius-md); overflow: hidden; background: linear-gradient(135deg, #BCC8C0 0%, #8FA398 50%, #6F8478 100%); position: relative; }
.nh-home .nh-img-ph.tall { aspect-ratio: 3/4; }
.nh-home .nh-img-ph.wide { aspect-ratio: 16/9; }
.nh-home .nh-img-ph::after { content: attr(data-label); position: absolute; bottom: 16px; left: 20px; color: rgba(255, 255, 255, 0.85); font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.8rem; letter-spacing: 0.15em; z-index: 1; }
.nh-home .nh-img-ph::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(180deg, transparent 60%, rgba(31, 63, 53, 0.25) 100%); }

/* ==============================================================
   7-B. Property detail page
   ============================================================== */
.nh-home .nh-property-detail-grid { display: grid; grid-template-columns: 7fr 5fr; gap: 48px; align-items: start; }
.nh-home .nh-property-detail-image { position: relative; border-radius: var(--nh-radius-md); overflow: hidden; aspect-ratio: 4/3; background: var(--nh-beige-deep); }
.nh-home .nh-property-detail-image img { width: 100%; height: 100%; object-fit: cover; }
.nh-home .nh-property-detail-status { position: absolute; top: 24px; left: 24px; background: var(--nh-gold); color: var(--nh-white); padding: 8px 18px; font-size: 0.8rem; letter-spacing: 0.12em; font-weight: 500; border-radius: var(--nh-radius-sm); z-index: 1; }
.nh-home .nh-property-detail-status.closed { background: var(--nh-text-subtle); }
.nh-home .nh-property-detail-summary { padding: 8px 0; }
.nh-home .nh-property-detail-summary .nh-property-meta { font-size: 0.85rem; margin-bottom: 12px; }
.nh-home .nh-property-detail-price { font-family: 'Noto Serif JP', serif; font-size: 2.4rem; font-weight: 700; color: var(--nh-green); margin-bottom: 24px; letter-spacing: 0.02em; line-height: 1.2; }
.nh-home .nh-property-detail-price small { font-size: 1rem; font-weight: 400; color: var(--nh-text-muted); margin-left: 4px; }
.nh-home .nh-property-detail-table { margin-bottom: 32px; }
.nh-home .nh-property-detail-table th { width: 130px; padding: 16px 18px; font-size: 0.85rem; }
.nh-home .nh-property-detail-table td { padding: 16px 18px; font-size: 0.9rem; }
.nh-home .nh-property-detail-actions { display: flex; flex-direction: column; gap: 12px; }
.nh-home .nh-property-detail-actions .nh-btn { justify-content: center; }

/* Gallery grid */
.nh-home .nh-gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.nh-home .nh-gallery-item { display: block; aspect-ratio: 4/3; overflow: hidden; border-radius: var(--nh-radius-sm); background: var(--nh-beige-deep); transition: all 0.3s var(--nh-ease); }
.nh-home .nh-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s var(--nh-ease); }
.nh-home .nh-gallery-item:hover { box-shadow: var(--nh-shadow-md); }
.nh-home .nh-gallery-item:hover img { transform: scale(1.04); }

/* Map embed */
.nh-home .nh-map-wrap { border-radius: var(--nh-radius-md); overflow: hidden; box-shadow: var(--nh-shadow-sm); }
.nh-home .nh-map-wrap iframe { display: block; width: 100%; height: 480px; border: 0; }

/* Pagination */
.nh-home .nh-pagination { display: flex; gap: 8px; justify-content: center; margin-top: 64px; flex-wrap: wrap; }
.nh-home .nh-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px; padding: 0 14px; font-size: 0.9rem; color: var(--nh-green-dark); background: var(--nh-white); border: 1px solid var(--nh-border); border-radius: var(--nh-radius-sm); transition: all 0.3s var(--nh-ease); font-family: 'Cormorant Garamond', serif; font-style: italic; letter-spacing: 0.05em; }
.nh-home .nh-pagination .page-numbers:hover { background: var(--nh-beige); border-color: var(--nh-green-mist); }
.nh-home .nh-pagination .page-numbers.current { background: var(--nh-green); color: var(--nh-white); border-color: var(--nh-green); }
.nh-home .nh-pagination .page-numbers.dots { background: transparent; border: none; }

/* ==============================================================
   8. Reveal animations
   ============================================================== */
.nh-home .nh-reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.9s var(--nh-ease), transform 0.9s var(--nh-ease); }
.nh-home .nh-reveal.visible { opacity: 1; transform: translateY(0); }
.nh-home .nh-stagger > * { opacity: 0; transform: translateY(20px); transition: opacity 0.7s var(--nh-ease), transform 0.7s var(--nh-ease); }
.nh-home .nh-stagger.visible > * { opacity: 1; transform: translateY(0); }
.nh-home .nh-stagger.visible > *:nth-child(1) { transition-delay: 0.05s; }
.nh-home .nh-stagger.visible > *:nth-child(2) { transition-delay: 0.15s; }
.nh-home .nh-stagger.visible > *:nth-child(3) { transition-delay: 0.25s; }
.nh-home .nh-stagger.visible > *:nth-child(4) { transition-delay: 0.35s; }
.nh-home .nh-stagger.visible > *:nth-child(5) { transition-delay: 0.45s; }
.nh-home .nh-stagger.visible > *:nth-child(6) { transition-delay: 0.55s; }

/* ==============================================================
   9. Responsive
   ============================================================== */
/* PC専用・SP専用の改行制御クラス */
.nh-home .pc-only { display: inline; }
.nh-home .sp-only { display: none; }
.nh-home .pc-br { display: inline; }
.nh-home .sp-br { display: none; }

@media (max-width: 960px) {
  .nh-home .nh-hero-photo { width: 100%; opacity: 0.32; border-radius: 0; }
  .nh-home .nh-hero-content { max-width: 100%; padding: 60px 0; }
  .nh-home .nh-purpose-grid, .nh-home .nh-services-grid, .nh-home .nh-properties-grid, .nh-home .nh-type-grid, .nh-home .nh-pillars { grid-template-columns: 1fr 1fr; }
  .nh-home .nh-news-grid, .nh-home .nh-area-grid, .nh-home .nh-rentals-grid, .nh-home .nh-company-grid, .nh-home .nh-cta-inner { grid-template-columns: 1fr; gap: 40px; }
  .nh-home .nh-rentals-visual, .nh-home .nh-area-photo, .nh-home .nh-company-image { min-height: 280px; }
  .nh-home .nh-rentals-content, .nh-home .nh-company-content { padding: 40px 32px; }
  .nh-home .nh-steps { grid-template-columns: 1fr 1fr; }
  .nh-home .nh-table th { width: 140px; padding: 18px; }
  .nh-home .nh-table td { padding: 18px; }
  .nh-home .nh-property-detail-grid { grid-template-columns: 1fr; gap: 32px; }
  .nh-home .nh-gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .nh-home .nh-map-wrap iframe { height: 360px; }
}

/* ============================================================
   SP（〜640px）最適化
   ============================================================ */
@media (max-width: 640px) {
  /* 改行制御 */
  .nh-home .pc-only, .nh-home .pc-br { display: none !important; }
  .nh-home .sp-only, .nh-home .sp-br { display: inline !important; }
  br.pc-br { display: none !important; }
  br.sp-br { display: inline !important; }

  /* コンテナ */
  .nh-home .nh-container { padding: 0 20px; }
  .nh-home .nh-container-sm { padding: 0 20px; }

  /* セクション余白 */
  .nh-home .nh-section, .nh-home .nh-section-alt, .nh-home .nh-section-dark { padding: 60px 0; }
  .nh-home .nh-page-header { padding: 60px 0 40px; }

  /* ヒーロー：写真と文字のコントラスト強化 */
  .nh-home .nh-hero { min-height: auto; padding: 30px 0 50px; }
  .nh-home .nh-hero .nh-container { padding-left: 20px !important; padding-right: 20px !important; }
  .nh-home .nh-hero-content { padding: 40px 0 20px; max-width: 100% !important; }
  .nh-home .nh-hero-photo { opacity: 0.22; }  /* SPは文字優先で写真薄め */
  .nh-home .nh-hero-photo::before { background: linear-gradient(180deg, rgba(244, 239, 230, 0.5) 0%, rgba(244, 239, 230, 0.7) 100%) !important; }
  .nh-home .nh-hero-title { font-size: 1.7rem; line-height: 1.6; letter-spacing: 0.04em; }
  .nh-home .nh-hero-subtitle { font-size: 0.92rem; line-height: 1.95; }
  .nh-home .nh-hero-eyebrow { font-size: 0.8rem; margin-bottom: 22px; }
  .nh-home .nh-hero-actions { flex-direction: column; gap: 12px; align-items: stretch; }
  .nh-home .nh-hero-actions .nh-btn { width: 100%; justify-content: center; padding: 16px 24px; }
  .nh-home .nh-hero-meta { display: none; }  /* SP は下部メタ情報非表示でスッキリ */

  /* セクションタイトル */
  .nh-home .nh-section-head { text-align: left; }
  .nh-home .nh-section-head.center { text-align: center; }
  .nh-home .nh-section-label { font-size: 0.78rem; letter-spacing: 0.15em; margin-bottom: 10px; }
  .nh-home .nh-section-title { font-size: 1.5rem; line-height: 1.55; margin-bottom: 16px; }
  .nh-home .nh-section-lead { font-size: 0.92rem; line-height: 1.95; }

  /* グリッド */
  .nh-home .nh-purpose-grid, .nh-home .nh-services-grid, .nh-home .nh-properties-grid, .nh-home .nh-type-grid, .nh-home .nh-pillars, .nh-home .nh-steps { grid-template-columns: 1fr; gap: 20px; }
  .nh-home .nh-purpose-card, .nh-home .nh-service-card, .nh-home .nh-pillar { padding: 32px 24px; }
  .nh-home .nh-area-stats { grid-template-columns: 1fr; gap: 28px; margin-top: 24px; }
  .nh-home .nh-area-stat-num { font-size: 2rem; }
  .nh-home .nh-area-stat-text { font-size: 1rem; min-height: auto; }
  .nh-home .nh-area-stat-label { font-size: 0.74rem; }

  /* エリアセクション */
  .nh-home .nh-area-content { padding: 0; }
  .nh-home .nh-area-quote { font-size: 1.05rem; line-height: 1.85; padding: 20px 0; margin: 24px 0; }
  .nh-home .nh-area-photo { aspect-ratio: 4/3; }

  /* CTAバナー */
  .nh-home .nh-cta { padding: 60px 0; }
  .nh-home .nh-cta-title { font-size: 1.5rem; line-height: 1.6; }
  .nh-home .nh-cta-desc { font-size: 0.92rem; line-height: 1.9; }
  .nh-home .nh-cta-actions { gap: 16px; }
  .nh-home .nh-cta-phone-num { font-size: 1.6rem; }

  /* お知らせ・ブログ列 */
  .nh-home .nh-news-col-title { font-size: 1rem; }
  .nh-home .nh-news-title { font-size: 0.92rem; line-height: 1.75; }
  .nh-home .nh-blog-item { grid-template-columns: 90px 1fr; gap: 16px; }
  .nh-home .nh-blog-thumb { aspect-ratio: 1; }

  /* 会社ティーザー */
  .nh-home .nh-company-quote { font-size: 1.4rem; line-height: 1.7; }
  .nh-home .nh-company-text { font-size: 0.92rem; line-height: 2; }
  .nh-home .nh-company-content { padding: 50px 24px; }
  .nh-home .nh-company-image { aspect-ratio: 4/3; }

  /* 賃貸CTA */
  .nh-home .nh-rentals-visual { aspect-ratio: 4/3; min-height: 0; }
  .nh-home .nh-rentals-content { padding: 50px 24px; }

  /* 物件カード */
  .nh-home .nh-property-image-wrap { aspect-ratio: 16/10; }
  .nh-home .nh-property-body { padding: 22px 20px 26px; }
  .nh-home .nh-property-title { font-size: 1rem; }
  .nh-home .nh-property-price { font-size: 1.4rem; }
  .nh-home .nh-property-specs { font-size: 0.78rem; gap: 8px; flex-wrap: wrap; }

  /* お知らせ帯 */
  .nh-home .nh-notice-inner { padding: 10px 0; gap: 10px; font-size: 0.82rem; line-height: 1.65; }
  .nh-home .nh-notice-label { font-size: 0.66rem; padding: 3px 10px; }

  /* テーブル */
  .nh-home .nh-table th, .nh-home .nh-table td { display: block; width: 100%; padding: 12px 16px; }
  .nh-home .nh-table th { background: var(--nh-beige); }

  /* 物件詳細 */
  .nh-home .nh-property-detail-price { font-size: 1.7rem; }
  .nh-home .nh-gallery-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .nh-home .nh-map-wrap iframe { height: 280px; }

  /* リンクボタン */
  .nh-home .nh-btn { font-size: 0.85rem; padding: 14px 22px; }
  .nh-home .nh-btn-large { padding: 16px 26px; font-size: 0.9rem; }

  /* テキストオーバーフロー対策 */
  .nh-home .nh-company-text,
  .nh-home .nh-company-quote,
  .nh-home .nh-area-quote,
  .nh-home .nh-section-lead,
  .nh-home .nh-content p,
  .nh-home .nh-pillar-desc,
  .nh-home .nh-service-desc,
  .nh-home .nh-purpose-desc,
  .nh-home .nh-type-desc,
  .nh-home .nh-step p,
  .nh-home .nh-cta-desc {
    max-width: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
    word-break: normal;
    line-break: strict;
  }
  .nh-home .nh-company-content,
  .nh-home .nh-area-content,
  .nh-home .nh-rentals-content,
  .nh-home .nh-cta-content {
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
  }
}

/* ============================================================
   Lightning デフォルトフッターナビ・余白の徹底排除
   （カスタムフッター情報ブロックと重複するため）
   ============================================================ */
#site-footer nav.global-nav,
#site-footer .global-nav,
#site-footer ul.menu,
#site-footer ul.nav,
#site-footer ul#footer-nav,
#site-footer nav#footer-navigation,
#site-footer nav[class*="nav"],
#site-footer .footer-navigation,
#site-footer #global-nav,
#site-footer .menu-footer-navigation-container,
#site-footer .menu-global-nav-container {
  display: none !important;
}
/* Lightning が独自に出してる container wrapper の余白も殺す */
#site-footer > .container,
#site-footer > .l-container,
#site-footer > .footer-bottom > .container { 
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
/* Copyright だけ表示。それ以外の wrapper を畳む */
#site-footer .site-info { 
  padding: 0 !important;
  margin: 0 !important;
}
  .nh-home .nh-property-detail-price { font-size: 2rem; }
  .nh-home .nh-gallery-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .nh-home .nh-map-wrap iframe { height: 280px; }
}

/* ==============================================================
   10. Lightning Header / Footer Customization
   （.nh-home スコープ外。サイト全ページに適用）
   ============================================================== */

/* ----- Header ----- */
#site-header {
	background: var(--nh-white);
	border-bottom: 1px solid var(--nh-border);
	padding: 16px 0;
	position: sticky;
	top: 0;
	z-index: 100;
	transition: box-shadow 0.3s var(--nh-ease);
}
.admin-bar #site-header { top: 32px; }
@media (max-width: 782px) { .admin-bar #site-header { top: 46px; } }
@media (max-width: 600px) { .admin-bar #site-header { position: relative; top: 0; } }

#site-header-container {
	max-width: var(--nh-container);
	margin: 0 auto;
	padding: 0 32px;
	display: flex !important;
	align-items: center;
	gap: 18px;
}

/* Flex order: Logo(default 0) → Nav(2, margin-left:auto) → CTA(3) */
#site-header .site-header-logo,
#site-header h1.site-header-logo,
#site-header div.site-header-logo { order: 0; }
#site-header #global-nav { order: 2; margin-left: auto; }
.nh-header-cta { order: 3; }

/* Logo / Site Title */
#site-header .site-header-logo,
#site-header h1.site-header-logo,
#site-header div.site-header-logo {
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.05em;
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	flex-shrink: 0;
	max-width: 280px;
	display: inline-flex !important;
	visibility: visible !important;
	opacity: 1 !important;
	height: auto !important;
	max-height: none !important;
	overflow: visible !important;
}

/* Force logo visible even when Lightning's header_scrool fires */
.scrolled #site-header .site-header-logo,
.is-scroll #site-header .site-header-logo,
.is-scrolled #site-header .site-header-logo,
body.scrolled #site-header .site-header-logo,
body.is-scroll #site-header .site-header-logo,
body.is-scrolled #site-header .site-header-logo,
#site-header.scrolled .site-header-logo,
#site-header.is-scroll .site-header-logo,
#site-header.is-scrolled .site-header-logo,
#site-header.scroll-hide .site-header-logo {
	display: inline-flex !important;
	visibility: visible !important;
	opacity: 1 !important;
	height: auto !important;
	max-height: none !important;
	overflow: visible !important;
	transform: none !important;
}

#site-header .site-header-logo a {
	color: var(--nh-green-dark);
	text-decoration: none;
	border: none;
	transition: color 0.3s var(--nh-ease);
	display: inline-flex;
	align-items: center;
	visibility: visible !important;
	opacity: 1 !important;
}
#site-header .site-header-logo a:hover { color: var(--nh-green); }
/* Logo image (Lightningカスタマイザーで設定した画像) */
#site-header .site-header-logo img,
#site-header .site-header-logo span img,
#site-header .site-header-logo span {
	display: inline-block !important;
	visibility: visible !important;
	opacity: 1 !important;
	max-height: 56px;
	width: auto;
	max-width: 240px;
	object-fit: contain;
}

/* Global Nav */
#site-header #global-nav {
	background: none !important;
	border: none !important;
}
#site-header .global-nav-list,
#site-header ul.global-nav-list,
#site-header #global-nav ul {
	display: flex !important;
	flex-wrap: nowrap;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	gap: 2px;
	background: none !important;
}
#site-header .global-nav-list > li {
	background: none !important;
	border: none !important;
	margin: 0 !important;
}
#site-header .global-nav-list > li > a {
	display: block;
	padding: 10px 12px !important;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.82rem !important;
	font-weight: 400;
	letter-spacing: 0.04em;
	color: var(--nh-text) !important;
	text-decoration: none !important;
	background: none !important;
	border: none !important;
	border-bottom: none !important;
	box-shadow: none !important;
	position: relative;
	white-space: nowrap;
	transition: color 0.3s var(--nh-ease);
}
/* Remove Lightning theme's default ::before pseudo-element (blue current-page indicator) */
#site-header .global-nav-list > li > a::before,
#site-header .global-nav-list > li.current-menu-item > a::before,
#site-header .global-nav-list > li.current_page_item > a::before,
#site-header .global-nav-list > li.current-menu-parent > a::before {
	content: none !important;
	display: none !important;
	background: none !important;
	border: none !important;
}
/* Nuke ALL Lightning nav decorations (borders, underlines, pseudo-elements) */
#site-header nav.global-nav,
#site-header nav.global-nav *,
#site-header #global-nav,
#site-header #global-nav *,
#site-header ul.global-nav-list,
#site-header ul.global-nav-list *,
#site-header ul.vk-menu-acc,
#site-header ul.vk-menu-acc *,
#site-header ul.nav,
#site-header ul.nav * {
	text-decoration: none !important;
	border-color: transparent !important;
}
#site-header nav.global-nav li,
#site-header nav.global-nav li > a,
#site-header #global-nav li,
#site-header #global-nav li > a,
#site-header ul.global-nav-list > li,
#site-header ul.global-nav-list > li > a,
#site-header ul.vk-menu-acc > li,
#site-header ul.vk-menu-acc > li > a,
#site-header ul.nav > li,
#site-header ul.nav > li > a {
	border: 0 !important;
	border-bottom: 0 !important;
	border-top: 0 !important;
	border-left: 0 !important;
	border-right: 0 !important;
	box-shadow: none !important;
	outline: none !important;
	text-decoration: none !important;
	background-image: none !important;
}
/* Kill any pseudo-elements on li and on link that could draw a line */
#site-header ul.global-nav-list > li::before,
#site-header ul.global-nav-list > li::after,
#site-header ul.vk-menu-acc > li::before,
#site-header ul.vk-menu-acc > li::after,
#site-header ul.nav > li::before,
#site-header ul.nav > li::after,
#site-header #global-nav li::before,
#site-header #global-nav li::after {
	content: none !important;
	display: none !important;
	background: transparent !important;
	border: 0 !important;
	width: 0 !important;
	height: 0 !important;
}
#site-header .global-nav-list > li > a::after {
	content: '';
	position: absolute;
	left: 12px;
	right: 12px;
	bottom: 4px;
	height: 1px;
	background: var(--nh-gold);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.35s var(--nh-ease);
}
#site-header .global-nav-list > li > a:hover { color: var(--nh-green-dark) !important; }
#site-header .global-nav-list > li > a:hover::after,
#site-header .global-nav-list > li.current-menu-item > a::after,
#site-header .global-nav-list > li.current_page_item > a::after,
#site-header .global-nav-list > li.current-menu-parent > a::after {
	transform: scaleX(1);
}
#site-header .global-nav-list > li.current-menu-item > a,
#site-header .global-nav-list > li.current_page_item > a {
	color: var(--nh-green-dark) !important;
}

/* Header Phone CTA */
.nh-header-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	background: var(--nh-green);
	color: var(--nh-white) !important;
	border-radius: var(--nh-radius-sm);
	text-decoration: none !important;
	transition: background 0.3s var(--nh-ease), transform 0.2s var(--nh-ease);
	flex-shrink: 0;
	line-height: 1;
}
.nh-header-cta:hover { background: var(--nh-green-dark); color: var(--nh-white) !important; transform: translateY(-1px); }
.nh-header-cta-icon { display: flex; align-items: center; flex-shrink: 0; }
.nh-header-cta-icon svg { width: 16px; height: 16px; }
.nh-header-cta-text { display: inline-flex; align-items: baseline; }
.nh-header-cta-label { display: none; }  /* コンパクト版ではラベル非表示 */
.nh-header-cta-number { font-family: 'Cormorant Garamond', serif; font-size: 0.98rem; letter-spacing: 0.04em; font-weight: 500; white-space: nowrap; }

@media (max-width: 1024px) {
	#site-header .global-nav-list > li > a { padding: 10px 10px !important; font-size: 0.8rem !important; }
	.nh-header-cta-text { display: none; }
	.nh-header-cta { padding: 9px 10px; gap: 0; }
	.nh-header-cta-icon svg { width: 18px; height: 18px; }
}
@media (max-width: 782px) {
	#site-header-container { flex-wrap: wrap; }
	.nh-header-cta { margin-left: auto; }
}

/* ----- Footer ----- */
#site-footer,
.site-footer,
footer.site-footer {
	background: var(--nh-green-dark) !important;
	color: rgba(255, 255, 255, 0.78);
	padding: 0;
	margin: 0;
	border: none;
	position: relative;
}
#site-footer::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 80% 100%, rgba(168, 139, 92, 0.12) 0%, transparent 60%), radial-gradient(circle at 20% 0%, rgba(90, 133, 116, 0.15) 0%, transparent 50%);
	pointer-events: none;
}
#site-footer * { position: relative; }
#site-footer a { color: rgba(255, 255, 255, 0.85); text-decoration: none; transition: color 0.3s var(--nh-ease); }
#site-footer a:hover { color: var(--nh-gold-light); }

/* Footer info block (custom prepend) */
.nh-footer-info { padding: 80px 0 60px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.nh-footer-info-inner { max-width: var(--nh-container); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 60px; align-items: start; }

.nh-footer-section-label {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.85rem;
	color: var(--nh-gold-light);
	letter-spacing: 0.18em;
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(168, 139, 92, 0.3);
}

/* Brand column */
.nh-footer-brand-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.78rem; color: var(--nh-gold-light); letter-spacing: 0.15em; margin-bottom: 16px; opacity: 0.85; }
.nh-footer-brand-name { font-family: 'Noto Serif JP', serif; font-size: 1.25rem; font-weight: 600; color: var(--nh-white); letter-spacing: 0.06em; margin: 0 0 18px; padding: 0; border: none; background: none; }
.nh-footer-brand-address { font-size: 0.85rem; line-height: 1.85; color: rgba(255, 255, 255, 0.7); margin: 0 0 14px; letter-spacing: 0.04em; }
.nh-footer-brand-license { font-size: 0.75rem; color: rgba(255, 255, 255, 0.5); margin: 0; letter-spacing: 0.06em; }

/* Contact column */
.nh-footer-phone { display: block; font-family: 'Cormorant Garamond', serif; font-size: 1.85rem; font-weight: 500; color: var(--nh-gold-light) !important; letter-spacing: 0.04em; margin-bottom: 12px; line-height: 1.1; }
.nh-footer-phone:hover { color: var(--nh-white) !important; }
.nh-footer-hours { font-size: 0.82rem; line-height: 1.85; color: rgba(255, 255, 255, 0.7); margin: 0 0 22px; letter-spacing: 0.04em; }
.nh-footer-inquiry-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.18); border-radius: var(--nh-radius-sm); font-size: 0.82rem; letter-spacing: 0.06em; color: var(--nh-white) !important; transition: all 0.3s var(--nh-ease); }
.nh-footer-inquiry-btn:hover { background: var(--nh-gold); border-color: var(--nh-gold); color: var(--nh-white) !important; }

/* Quick Links column */
.nh-footer-link-list { list-style: none; margin: 0 0 24px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px; }
.nh-footer-link-list li { padding: 0; margin: 0; }
.nh-footer-link-list a { display: inline-block; padding: 4px 0; font-size: 0.82rem; color: rgba(255, 255, 255, 0.78) !important; letter-spacing: 0.04em; position: relative; }
.nh-footer-link-list a::before { content: '→ '; color: var(--nh-gold); opacity: 0; margin-right: 0; transition: all 0.3s var(--nh-ease); }
.nh-footer-link-list a:hover { color: var(--nh-white) !important; }
.nh-footer-link-list a:hover::before { opacity: 1; margin-right: 4px; }

/* SNS icons */
.nh-footer-sns { display: flex; gap: 10px; margin-top: 8px; }
.nh-footer-sns a { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 50%; color: rgba(255, 255, 255, 0.85) !important; transition: all 0.3s var(--nh-ease); }
.nh-footer-sns a:hover { background: var(--nh-gold); border-color: var(--nh-gold); color: var(--nh-white) !important; transform: translateY(-2px); }

/* Lightning's default footer nav (subtle) */
#site-footer .global-nav-list,
#site-footer ul.menu,
#site-footer ul {
	display: flex !important;
	list-style: none !important;
	margin: 30px auto !important;
	padding: 30px 32px 0 !important;
	max-width: var(--nh-container);
	justify-content: center;
	flex-wrap: wrap;
	gap: 4px 28px;
	background: none !important;
	border: none !important;
}
#site-footer .global-nav-list { display: none !important; } /* Hide duplicate nav since we have Quick Links */

/* Copyright */
#site-footer .copyright,
#site-footer .copyright-text,
#site-footer p {
	text-align: center;
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.78rem !important;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.45) !important;
	padding: 24px 32px !important;
	margin: 0 !important;
	background: rgba(0, 0, 0, 0.15);
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}
#site-footer .copyright a, #site-footer p a { color: rgba(255, 255, 255, 0.7) !important; }

/* Hide Powered by */
#site-footer .credit,
#site-footer .powered-by,
#site-footer [class*="powered"],
.site-info { display: none !important; }

/* Footer Responsive */
@media (max-width: 960px) {
	.nh-footer-info-inner { grid-template-columns: 1fr 1fr; gap: 40px 32px; }
	.nh-footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
	.nh-footer-info { padding: 60px 0 40px; }
	.nh-footer-info-inner { grid-template-columns: 1fr; gap: 40px; padding: 0 24px; }
	.nh-footer-link-list { grid-template-columns: 1fr; }
	.nh-footer-phone { font-size: 1.5rem; }
}

/* ==============================================================
   11. Lightning Default Page Header Suppression
   下層ページでLightningが自動表示する青い帯と装飾線を全て隠す
   （自前の .nh-page-header と重複するため）
   ============================================================== */

/* Lightning の page-header 系を全部消す */
.page-header-outer,
.page-header,
section.page-header,
header.page-header,
.entry-header.page-header,
.page-header-area,
.page-header-section,
#page-header,
.lightning-page-header,
.vk-page-header,
body.page .page-header:not(.nh-page-header),
body.archive .page-header:not(.nh-page-header),
body.single .page-header:not(.nh-page-header) {
	display: none !important;
}

/* 上端の青ライン（border-top や top decoration） */
body { border-top: 0 !important; }
body::before { content: none !important; display: none !important; }
.color-band, .top-band, .header-band, .lightning-color-band { display: none !important; }

/* Lightning のデフォルトのカラーパネル上端装飾 */
.entry-body > .page-header,
.l-container > .page-header,
.l-section > .page-header,
.site-body > .page-header,
.site-content > .page-header { display: none !important; }

/* ==============================================================
   12. SP Hamburger Menu + Overlay Nav
   ============================================================== */

/* Hamburger button (hidden by default, visible on SP) */
.nh-hamburger {
	display: none;
	position: relative;
	width: 44px;
	height: 44px;
	padding: 0;
	background: transparent;
	border: none;
	cursor: pointer;
	flex-shrink: 0;
	order: 4;
	z-index: 110;
}
.nh-hamburger span {
	display: block;
	position: absolute;
	left: 10px;
	right: 10px;
	height: 1.5px;
	background: var(--nh-green-dark);
	transition: all 0.35s var(--nh-ease);
}
.nh-hamburger span:nth-child(1) { top: 14px; }
.nh-hamburger span:nth-child(2) { top: 21px; }
.nh-hamburger span:nth-child(3) { top: 28px; }

/* Hamburger animation when open */
.nh-nav-open .nh-hamburger span { background: var(--nh-white); }
.nh-nav-open .nh-hamburger span:nth-child(1) { top: 21px; transform: rotate(45deg); }
.nh-nav-open .nh-hamburger span:nth-child(2) { opacity: 0; }
.nh-nav-open .nh-hamburger span:nth-child(3) { top: 21px; transform: rotate(-45deg); }

/* Body scroll lock when menu open */
body.nh-nav-open { overflow: hidden; }

@media (max-width: 768px) {
	/* Show hamburger, hide phone CTA text */
	.nh-hamburger { display: block !important; }

	/* Force mobile nav as fixed overlay (override Lightning) */
	#site-header #global-nav,
	#site-header nav.global-nav,
	nav.nh-nav-mobile,
	#global-nav.nh-nav-mobile {
		position: fixed !important;
		top: 0 !important;
		right: 0 !important;
		left: auto !important;
		bottom: auto !important;
		width: 100% !important;
		max-width: 100% !important;
		height: 100vh !important;
		min-height: 100vh !important;
		background: var(--nh-green-dark) !important;
		background-image: radial-gradient(circle at 80% 100%, rgba(168, 139, 92, 0.18) 0%, transparent 60%), radial-gradient(circle at 20% 0%, rgba(90, 133, 116, 0.2) 0%, transparent 50%) !important;
		padding: 90px 32px 60px !important;
		transform: translateX(100%) !important;
		transition: transform 0.45s cubic-bezier(0.6, 0, 0.3, 1) !important;
		z-index: 9999 !important;
		overflow-y: auto !important;
		margin: 0 !important;
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		border: none !important;
		box-shadow: none !important;
	}
	body.nh-nav-open #site-header #global-nav,
	body.nh-nav-open #site-header nav.global-nav,
	body.nh-nav-open nav.nh-nav-mobile,
	body.nh-nav-open #global-nav.nh-nav-mobile {
		transform: translateX(0) !important;
	}

	/* Nav list in mobile overlay */
	#site-header .global-nav-list,
	#site-header ul.global-nav-list,
	#site-header #global-nav ul {
		flex-direction: column !important;
		gap: 0 !important;
		align-items: stretch !important;
		max-width: 480px;
		margin: 0 auto !important;
		padding: 0 !important;
		display: flex !important;
	}
	#site-header .global-nav-list > li {
		border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
		display: block !important;
	}
	#site-header .global-nav-list > li > a {
		display: block !important;
		padding: 20px 4px !important;
		font-family: 'Noto Serif JP', serif !important;
		font-size: 1.05rem !important;
		font-weight: 500 !important;
		color: rgba(255, 255, 255, 0.92) !important;
		letter-spacing: 0.06em !important;
		text-align: left !important;
		white-space: nowrap;
		position: relative;
		opacity: 1 !important;
		visibility: visible !important;
	}
	#site-header .global-nav-list > li > a::before {
		content: '— ' !important;
		font-family: 'Cormorant Garamond', serif !important;
		font-style: italic;
		font-size: 0.75rem;
		color: var(--nh-gold-light);
		letter-spacing: 0.15em;
		margin-right: 12px;
		opacity: 0.7;
		display: inline-block !important;
		background: none !important;
		border: 0 !important;
		width: auto !important;
		height: auto !important;
	}
	#site-header .global-nav-list > li > a::after {
		content: '→' !important;
		position: absolute;
		right: 8px;
		top: 50%;
		transform: translateY(-50%) !important;
		font-family: 'Cormorant Garamond', serif;
		font-size: 1rem;
		color: var(--nh-gold);
		background: none !important;
		opacity: 0.5;
		left: auto;
		bottom: auto;
		height: auto;
		width: auto;
		display: block !important;
	}
	#site-header .global-nav-list > li.current-menu-item > a,
	#site-header .global-nav-list > li.current_page_item > a {
		color: var(--nh-gold-light) !important;
	}
	#site-header .global-nav-list > li.current-menu-item > a::after,
	#site-header .global-nav-list > li.current_page_item > a::after {
		opacity: 1;
		transform: translateY(-50%) translateX(4px) !important;
	}

	/* Adjust header layout on mobile - hamburger fixed at right via absolute positioning */
	#site-header { position: sticky; padding: 12px 0 !important; }
	#site-header-container {
		padding: 0 16px !important;
		padding-right: 64px !important;  /* ハンバーガー用スペース確保 */
		gap: 8px !important;
		position: relative !important;
	}
	#site-header .site-header-logo {
		max-width: 160px !important;
	}
	#site-header .site-header-logo img {
		max-height: 40px !important;
		max-width: 160px !important;
	}
	.nh-header-cta {
		padding: 9px 10px !important;
		order: 3;
		margin-left: auto !important;
	}
	.nh-hamburger {
		display: block !important;
		position: absolute !important;
		right: 12px !important;
		top: 50% !important;
		transform: translateY(-50%) !important;
		order: 4;
		z-index: 10001 !important;
		background: rgba(244, 239, 230, 0.5) !important;
	}
	.nh-nav-open .nh-hamburger {
		background: transparent !important;
	}
}

@media (max-width: 480px) {
	/* On very small screens, even tighter */
	.nh-header-cta { padding: 10px !important; }
	#site-header .site-header-logo img { max-height: 44px !important; }
}

/* ==============================================================
   13. Blog Hub (お役立ちコンテンツ) - Magazine Layout
   ============================================================== */

/* ----- Hub Intro ----- */
.nh-home .nh-blog-hub-intro {
	background: var(--nh-beige);
	padding: 80px 0 40px;
}
.nh-home .nh-blog-hub-intro-inner {
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
}
.nh-home .nh-blog-hub-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 2.25rem;
	font-weight: 700;
	color: var(--nh-green-dark);
	letter-spacing: 0.08em;
	margin: 12px 0 20px;
	line-height: 1.4;
}
.nh-home .nh-blog-hub-lead {
	font-size: 0.95rem;
	line-height: 2;
	color: var(--nh-text-muted);
	letter-spacing: 0.04em;
	margin: 0;
}

/* ----- Hero Featured Article ----- */
.nh-home .nh-blog-hero {
	background: var(--nh-beige);
	padding: 20px 0 80px;
}
.nh-home .nh-blog-hero-card {
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	gap: 0;
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	overflow: hidden;
	box-shadow: 0 20px 60px rgba(31, 63, 53, 0.08);
	text-decoration: none;
	transition: transform 0.4s var(--nh-ease), box-shadow 0.4s var(--nh-ease);
}
.nh-home .nh-blog-hero-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 30px 80px rgba(31, 63, 53, 0.12);
}
.nh-home .nh-blog-hero-visual {
	background-size: cover;
	background-position: center;
	background-color: var(--nh-green-mist);
	min-height: 420px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(47, 93, 78, 0.3);
}
.nh-home .nh-blog-hero-body {
	padding: 60px 50px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.nh-home .nh-blog-hero-date {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.9rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
	margin-bottom: 16px;
}
.nh-home .nh-blog-hero-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.7rem;
	font-weight: 700;
	color: var(--nh-green-dark);
	line-height: 1.55;
	letter-spacing: 0.04em;
	margin: 0 0 20px;
}
.nh-home .nh-blog-hero-excerpt {
	font-size: 0.9rem;
	line-height: 1.9;
	color: var(--nh-text-muted);
	margin: 0 0 28px;
}
.nh-home .nh-blog-hero-meta {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}
.nh-home .nh-blog-hero-arrow {
	margin-left: auto;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--nh-green);
	letter-spacing: 0.06em;
	font-size: 0.95rem;
}

/* ----- Blog Tag (small chip) ----- */
.nh-home .nh-blog-tag {
	display: inline-block;
	padding: 3px 10px;
	background: var(--nh-beige-soft);
	color: var(--nh-green-dark);
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	border-radius: 3px;
	border: 1px solid var(--nh-border);
	white-space: nowrap;
}

/* ----- Section Head (magazine style) ----- */
.nh-home .nh-blog-section-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: 40px;
}
.nh-home .nh-blog-section-title-sub {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.9rem;
	font-weight: 400;
	color: var(--nh-text-muted);
	margin-left: 16px;
	letter-spacing: 0.06em;
}
.nh-home .nh-blog-section-sub {
	font-size: 0.9rem;
	color: var(--nh-text-muted);
	margin: 4px 0 0;
	letter-spacing: 0.04em;
}

/* ----- Blog Card (共通) ----- */
.nh-home .nh-blog-card {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: transform 0.35s var(--nh-ease);
}
.nh-home .nh-blog-card:hover { transform: translateY(-4px); }
.nh-home .nh-blog-card-image {
	aspect-ratio: 4/3;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	border-radius: var(--nh-radius);
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(47, 93, 78, 0.25);
	transition: opacity 0.35s var(--nh-ease);
}
.nh-home .nh-blog-card:hover .nh-blog-card-image { opacity: 0.85; }
.nh-home .nh-blog-card-body { padding: 20px 4px 0; }
.nh-home .nh-blog-card-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}
.nh-home .nh-blog-card-date {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.82rem;
	color: var(--nh-gold);
	letter-spacing: 0.08em;
}
.nh-home .nh-blog-card-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--nh-text);
	line-height: 1.65;
	letter-spacing: 0.03em;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ----- Featured Grid (特集: 3列) ----- */
.nh-home .nh-blog-featured-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}

/* ----- Tag/Category Browser ----- */
.nh-home .nh-blog-taxonomy-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 60px;
	align-items: start;
}
.nh-home .nh-blog-tags-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 20px 0 32px;
}
.nh-home .nh-blog-tag-chip {
	display: inline-block;
	padding: 8px 16px;
	background: var(--nh-white);
	color: var(--nh-green-dark);
	font-size: 0.82rem;
	letter-spacing: 0.04em;
	border-radius: 20px;
	border: 1px solid var(--nh-border);
	text-decoration: none;
	transition: all 0.3s var(--nh-ease);
}
.nh-home .nh-blog-tag-chip:hover {
	background: var(--nh-green);
	color: var(--nh-white);
	border-color: var(--nh-green);
	transform: translateY(-1px);
}
.nh-home .nh-blog-search {
	display: flex;
	max-width: 500px;
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	border-radius: var(--nh-radius-sm);
	overflow: hidden;
	margin-top: 8px;
}
.nh-home .nh-blog-search-input {
	flex: 1;
	padding: 12px 18px;
	border: none;
	background: transparent;
	font-size: 0.9rem;
	outline: none;
	color: var(--nh-text);
	font-family: inherit;
}
.nh-home .nh-blog-search-btn {
	padding: 0 20px;
	background: var(--nh-green);
	color: var(--nh-white);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	transition: background 0.3s var(--nh-ease);
}
.nh-home .nh-blog-search-btn:hover { background: var(--nh-green-dark); }

.nh-home .nh-blog-taxonomy-side {
	background: var(--nh-white);
	padding: 30px 30px;
	border-radius: var(--nh-radius);
	border: 1px solid var(--nh-border);
}
.nh-home .nh-blog-side-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	margin: 8px 0 20px;
	letter-spacing: 0.06em;
}
.nh-home .nh-blog-cat-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.nh-home .nh-blog-cat-list li {
	border-bottom: 1px solid var(--nh-border);
}
.nh-home .nh-blog-cat-list li:last-child { border-bottom: 0; }
.nh-home .nh-blog-cat-list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 4px;
	color: var(--nh-text);
	text-decoration: none;
	font-size: 0.9rem;
	transition: color 0.3s var(--nh-ease);
}
.nh-home .nh-blog-cat-list a:hover { color: var(--nh-green); }
.nh-home .nh-blog-cat-name { letter-spacing: 0.04em; }
.nh-home .nh-blog-cat-count {
	font-family: 'Cormorant Garamond', serif;
	color: var(--nh-gold);
	font-size: 0.9rem;
	letter-spacing: 0.08em;
}

/* ----- Recommended Grid (おすすめ: 3列 x 2行) ----- */
.nh-home .nh-blog-recommended-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px 32px;
}

/* ----- Latest List (縦リスト) ----- */
.nh-home .nh-blog-latest-list {
	display: flex;
	flex-direction: column;
	gap: 0;
	max-width: 880px;
	margin: 0 auto;
}
.nh-home .nh-blog-latest-item {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 24px;
	padding: 24px 0;
	border-bottom: 1px solid var(--nh-border);
	text-decoration: none;
	color: inherit;
	align-items: center;
	transition: background 0.3s var(--nh-ease);
}
.nh-home .nh-blog-latest-item:hover { background: var(--nh-beige-soft); }
.nh-home .nh-blog-latest-item:first-child { padding-top: 0; }
.nh-home .nh-blog-latest-thumb {
	aspect-ratio: 4/3;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	border-radius: var(--nh-radius-sm);
	position: relative;
	overflow: hidden;
}
.nh-home .nh-blog-new-badge {
	position: absolute;
	top: 8px;
	left: 8px;
	background: #E74C3C;
	color: var(--nh-white);
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	padding: 2px 8px;
	border-radius: 2px;
}
.nh-home .nh-blog-latest-body { padding: 0 8px; }
.nh-home .nh-blog-latest-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1rem;
	font-weight: 600;
	color: var(--nh-text);
	line-height: 1.6;
	letter-spacing: 0.03em;
	margin: 6px 0 8px;
}
.nh-home .nh-blog-latest-date {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.82rem;
	color: var(--nh-gold);
	letter-spacing: 0.08em;
}

/* ----- Bottom CTA Banner ----- */
.nh-home .nh-blog-cta-banner {
	background: var(--nh-green-dark);
	background-image: radial-gradient(circle at 80% 100%, rgba(168, 139, 92, 0.18) 0%, transparent 60%), radial-gradient(circle at 20% 0%, rgba(90, 133, 116, 0.2) 0%, transparent 50%);
	padding: 100px 0;
	color: var(--nh-white);
	position: relative;
	overflow: hidden;
}
.nh-home .nh-blog-cta-banner-inner {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 32px;
	text-align: center;
	position: relative;
	z-index: 2;
}
.nh-home .nh-blog-cta-eyebrow {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.9rem;
	color: var(--nh-gold-light);
	letter-spacing: 0.2em;
	margin-bottom: 20px;
}
.nh-home .nh-blog-cta-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 2.25rem;
	font-weight: 700;
	color: var(--nh-white);
	line-height: 1.5;
	letter-spacing: 0.08em;
	margin: 0 0 22px;
}
.nh-home .nh-blog-cta-text {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.95;
	letter-spacing: 0.04em;
	margin: 0 0 40px;
}
.nh-home .nh-blog-cta-actions {
	display: flex;
	gap: 20px;
	justify-content: center;
	flex-wrap: wrap;
}

/* ----- Responsive ----- */
@media (max-width: 960px) {
	.nh-home .nh-blog-hero-card { grid-template-columns: 1fr; }
	.nh-home .nh-blog-hero-visual { min-height: 260px; aspect-ratio: 16/10; }
	.nh-home .nh-blog-hero-body { padding: 40px 32px; }
	.nh-home .nh-blog-hero-title { font-size: 1.4rem; }
	.nh-home .nh-blog-featured-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
	.nh-home .nh-blog-recommended-grid { grid-template-columns: repeat(2, 1fr); gap: 32px 24px; }
	.nh-home .nh-blog-taxonomy-grid { grid-template-columns: 1fr; gap: 40px; }
	.nh-home .nh-blog-taxonomy-side { max-width: 100%; }
}
@media (max-width: 640px) {
	.nh-home .nh-blog-hub-intro { padding: 60px 0 30px; }
	.nh-home .nh-blog-hub-title { font-size: 1.65rem; }
	.nh-home .nh-blog-hub-lead { font-size: 0.88rem; }
	.nh-home .nh-blog-hero { padding: 10px 0 50px; }
	.nh-home .nh-blog-hero-body { padding: 32px 24px; }
	.nh-home .nh-blog-hero-title { font-size: 1.2rem; }
	.nh-home .nh-blog-hero-excerpt { font-size: 0.85rem; }
	.nh-home .nh-blog-featured-grid,
	.nh-home .nh-blog-recommended-grid { grid-template-columns: 1fr; gap: 32px; }
	.nh-home .nh-blog-section-head { flex-direction: column; align-items: flex-start; gap: 12px; }
	.nh-home .nh-blog-section-title-sub { margin-left: 0; display: block; margin-top: 4px; }
	.nh-home .nh-blog-latest-item { grid-template-columns: 100px 1fr; gap: 16px; padding: 20px 0; }
	.nh-home .nh-blog-latest-title { font-size: 0.92rem; }
	.nh-home .nh-blog-tag-chip { font-size: 0.75rem; padding: 6px 12px; }
	.nh-home .nh-blog-taxonomy-side { padding: 24px 20px; }
	.nh-home .nh-blog-cta-banner { padding: 70px 0; }
	.nh-home .nh-blog-cta-title { font-size: 1.5rem; }
	.nh-home .nh-blog-cta-text { font-size: 0.9rem; }
}

/* ==============================================================
   14. Single Article Page (Magazine Layout)
   ============================================================== */

/* ----- Breadcrumb ----- */
.nh-home .nh-article-crumb {
	background: var(--nh-beige);
	padding: 24px 0;
	border-bottom: 1px solid var(--nh-border);
}
.nh-home .nh-breadcrumb {
	font-size: 0.8rem;
	color: var(--nh-text-muted);
	letter-spacing: 0.05em;
}
.nh-home .nh-breadcrumb a {
	color: var(--nh-text-muted);
	text-decoration: none;
	transition: color 0.3s var(--nh-ease);
}
.nh-home .nh-breadcrumb a:hover { color: var(--nh-green); }
.nh-home .nh-crumb-sep {
	margin: 0 8px;
	color: var(--nh-gold);
	font-family: 'Cormorant Garamond', serif;
}
.nh-home .nh-crumb-current {
	color: var(--nh-green-dark);
	font-weight: 500;
}

/* ----- Article Layout (2 columns) ----- */
.nh-home .nh-article-section {
	background: var(--nh-beige-soft);
	padding: 60px 0 100px;
}
.nh-home .nh-article-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 60px;
	align-items: start;
}

/* ----- Article Main ----- */
.nh-home .nh-article-main {
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	overflow: hidden;
	box-shadow: 0 8px 40px rgba(31, 63, 53, 0.05);
}
.nh-home .nh-article-hero-image {
	aspect-ratio: 16/9;
	background-size: cover;
	background-position: center;
	background-color: var(--nh-green-mist);
}

.nh-home .nh-article-header {
	padding: 50px 60px 30px;
	border-bottom: 1px solid var(--nh-border);
}
.nh-home .nh-article-meta-top {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 20px;
}
.nh-home .nh-article-cat {
	display: inline-block;
	padding: 6px 14px;
	background: var(--nh-green-dark);
	color: var(--nh-white) !important;
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	border-radius: 2px;
	text-decoration: none;
	transition: background 0.3s var(--nh-ease);
}
.nh-home .nh-article-cat:hover { background: var(--nh-green); }
.nh-home .nh-article-date {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.9rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
}
.nh-home .nh-article-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 2rem;
	font-weight: 700;
	color: var(--nh-green-dark);
	line-height: 1.55;
	letter-spacing: 0.04em;
	margin: 0 0 24px;
}
.nh-home .nh-article-author {
	display: flex;
	align-items: baseline;
	gap: 10px;
	font-size: 0.85rem;
	color: var(--nh-text-muted);
}
.nh-home .nh-article-author-label {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--nh-gold);
	letter-spacing: 0.1em;
}
.nh-home .nh-article-author-name {
	color: var(--nh-text);
	letter-spacing: 0.04em;
}

/* ----- Article Body Typography (Critical) ----- */
.nh-home .nh-article-body {
	padding: 50px 60px;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1rem;
	line-height: 2;
	color: var(--nh-text);
	letter-spacing: 0.05em;
}
.nh-home .nh-article-body > * { margin: 0 0 1.6em; }
.nh-home .nh-article-body > *:last-child { margin-bottom: 0; }

.nh-home .nh-article-body p { margin: 0 0 1.6em; }

.nh-home .nh-article-body h2 {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--nh-green-dark);
	line-height: 1.6;
	letter-spacing: 0.04em;
	padding: 0 0 0 18px;
	margin: 3em 0 1.2em;
	border-left: 4px solid var(--nh-gold);
	position: relative;
}
.nh-home .nh-article-body h3 {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	line-height: 1.65;
	letter-spacing: 0.04em;
	margin: 2.4em 0 1em;
	padding: 0 0 8px;
	border-bottom: 1px solid var(--nh-border);
}
.nh-home .nh-article-body h4 {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	margin: 2em 0 0.8em;
	letter-spacing: 0.04em;
}

.nh-home .nh-article-body a {
	color: var(--nh-green);
	text-decoration: underline;
	text-decoration-color: var(--nh-gold);
	text-underline-offset: 4px;
	transition: color 0.3s var(--nh-ease);
}
.nh-home .nh-article-body a:hover { color: var(--nh-green-dark); }

.nh-home .nh-article-body strong { font-weight: 700; color: var(--nh-green-dark); }
.nh-home .nh-article-body em { font-style: italic; color: var(--nh-gold); }

.nh-home .nh-article-body ul,
.nh-home .nh-article-body ol {
	padding: 0 0 0 1.5em;
	margin: 0 0 1.6em;
}
.nh-home .nh-article-body li { margin: 0 0 0.5em; line-height: 1.9; }
.nh-home .nh-article-body ul li::marker { color: var(--nh-gold); }
.nh-home .nh-article-body ol li::marker { color: var(--nh-gold); font-family: 'Cormorant Garamond', serif; }

.nh-home .nh-article-body blockquote {
	background: var(--nh-beige-soft);
	border-left: 3px solid var(--nh-green);
	padding: 24px 30px;
	margin: 2em 0;
	font-style: italic;
	color: var(--nh-green-dark);
	font-family: 'Noto Serif JP', serif;
	line-height: 1.9;
	border-radius: 0 var(--nh-radius-sm) var(--nh-radius-sm) 0;
}
.nh-home .nh-article-body blockquote p:last-child { margin-bottom: 0; }

.nh-home .nh-article-body img,
.nh-home .nh-article-body figure {
	max-width: 100%;
	height: auto;
	border-radius: var(--nh-radius-sm);
	margin: 2em 0;
}
.nh-home .nh-article-body figure figcaption {
	font-size: 0.82rem;
	color: var(--nh-text-muted);
	text-align: center;
	margin-top: 10px;
	letter-spacing: 0.05em;
}

.nh-home .nh-article-body code {
	background: var(--nh-beige);
	padding: 2px 8px;
	border-radius: 3px;
	font-size: 0.9em;
	color: var(--nh-green-dark);
}
.nh-home .nh-article-body pre {
	background: var(--nh-green-dark);
	color: var(--nh-white);
	padding: 20px 24px;
	border-radius: var(--nh-radius-sm);
	overflow-x: auto;
	font-size: 0.85rem;
	line-height: 1.7;
}
.nh-home .nh-article-body pre code { background: none; padding: 0; color: inherit; }

.nh-home .nh-article-body hr {
	border: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--nh-border), transparent);
	margin: 3em 0;
}

.nh-home .nh-article-body table {
	width: 100%;
	border-collapse: collapse;
	margin: 2em 0;
	font-size: 0.9rem;
}
.nh-home .nh-article-body table th {
	background: var(--nh-green-dark);
	color: var(--nh-white);
	padding: 12px 16px;
	text-align: left;
	font-weight: 600;
	letter-spacing: 0.04em;
}
.nh-home .nh-article-body table td {
	padding: 12px 16px;
	border-bottom: 1px solid var(--nh-border);
}

/* ----- Article Footer (Tags + Share) ----- */
.nh-home .nh-article-footer {
	padding: 40px 60px 50px;
	border-top: 1px solid var(--nh-border);
	background: var(--nh-beige-soft);
}
.nh-home .nh-article-tags,
.nh-home .nh-article-share {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 20px;
	flex-wrap: wrap;
}
.nh-home .nh-article-share { margin-bottom: 0; }
.nh-home .nh-article-tags-label,
.nh-home .nh-article-share-label {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.85rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
	white-space: nowrap;
}
.nh-home .nh-article-tags-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.nh-home .nh-article-share-list {
	display: flex;
	gap: 8px;
}
.nh-home .nh-article-share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	color: var(--nh-green-dark);
	border-radius: 50%;
	cursor: pointer;
	transition: all 0.3s var(--nh-ease);
	text-decoration: none;
}
.nh-home .nh-article-share-btn:hover {
	background: var(--nh-green);
	color: var(--nh-white);
	border-color: var(--nh-green);
	transform: translateY(-2px);
}
.nh-home .nh-article-share-btn.nh-copied {
	background: var(--nh-gold);
	color: var(--nh-white);
	border-color: var(--nh-gold);
}

/* ----- Sidebar ----- */
.nh-home .nh-article-sidebar { position: relative; }
.nh-home .nh-article-sidebar-sticky {
	position: sticky;
	top: 100px;
	display: flex;
	flex-direction: column;
	gap: 32px;
}
.nh-home .nh-article-sidebar-box {
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	border-radius: var(--nh-radius);
	padding: 26px 24px;
}
.nh-home .nh-article-sidebar-head { margin-bottom: 18px; }
.nh-home .nh-article-sidebar-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	margin: 6px 0 0;
	letter-spacing: 0.06em;
}

/* Ranking */
.nh-home .nh-article-ranking-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.nh-home .nh-article-ranking-item a {
	display: grid;
	grid-template-columns: auto 80px 1fr;
	gap: 12px;
	align-items: center;
	text-decoration: none;
	color: inherit;
	padding: 10px 0;
	border-bottom: 1px solid var(--nh-border);
	transition: opacity 0.3s var(--nh-ease);
}
.nh-home .nh-article-ranking-item:last-child a { border-bottom: 0; }
.nh-home .nh-article-ranking-item a:hover { opacity: 0.7; }
.nh-home .nh-article-ranking-num {
	font-family: 'Cormorant Garamond', serif;
	font-size: 1.6rem;
	font-weight: 500;
	color: var(--nh-gold);
	letter-spacing: 0.04em;
	line-height: 1;
}
.nh-home .nh-article-ranking-thumb {
	aspect-ratio: 1;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	border-radius: 4px;
}
.nh-home .nh-article-ranking-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--nh-text);
	line-height: 1.55;
	margin: 0 0 6px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.nh-home .nh-article-ranking-date {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.72rem;
	color: var(--nh-gold);
	letter-spacing: 0.08em;
}

/* ----- Responsive ----- */
@media (max-width: 1024px) {
	.nh-home .nh-article-layout { grid-template-columns: 1fr; gap: 40px; }
	.nh-home .nh-article-sidebar-sticky { position: static; flex-direction: row; flex-wrap: wrap; gap: 20px; }
	.nh-home .nh-article-sidebar-box { flex: 1 1 300px; }
}
@media (max-width: 640px) {
	.nh-home .nh-article-section { padding: 40px 0 60px; }
	.nh-home .nh-article-header { padding: 32px 24px 24px; }
	.nh-home .nh-article-title { font-size: 1.35rem; }
	.nh-home .nh-article-body { padding: 32px 24px; font-size: 0.95rem; line-height: 1.95; letter-spacing: 0.04em; }
	.nh-home .nh-article-body h2 { font-size: 1.25rem; padding-left: 14px; border-left-width: 3px; }
	.nh-home .nh-article-body h3 { font-size: 1.05rem; }
	.nh-home .nh-article-body blockquote { padding: 18px 20px; }
	.nh-home .nh-article-footer { padding: 30px 24px 32px; }
	.nh-home .nh-article-sidebar-sticky { flex-direction: column; }
	.nh-home .nh-article-sidebar-box { padding: 22px 20px; }
	.nh-home .nh-article-ranking-item a { grid-template-columns: auto 64px 1fr; gap: 10px; }
	.nh-home .nh-article-ranking-num { font-size: 1.3rem; }
	.nh-home .nh-breadcrumb { font-size: 0.75rem; }
	.nh-home .nh-breadcrumb a { display: inline-block; max-width: 100px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; vertical-align: bottom; }
	.nh-home .nh-crumb-current { display: inline-block; max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; vertical-align: bottom; }
}

/* ==============================================================
   15. News Archive (お知らせ) - Chronological List Layout
   ============================================================== */

.nh-home .nh-news-list {
	display: flex;
	flex-direction: column;
	max-width: 960px;
	margin: 0 auto;
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(31, 63, 53, 0.04);
}
.nh-home .nh-news-row {
	display: grid;
	grid-template-columns: 120px auto 1fr 24px;
	gap: 24px;
	padding: 26px 32px;
	border-bottom: 1px solid var(--nh-border);
	text-decoration: none;
	color: inherit;
	align-items: center;
	transition: background 0.3s var(--nh-ease);
}
.nh-home .nh-news-row:last-child { border-bottom: 0; }
.nh-home .nh-news-row:hover {
	background: var(--nh-beige-soft);
}
.nh-home .nh-news-row:hover .nh-news-row-arrow {
	color: var(--nh-gold);
	transform: translateX(4px);
}

/* Date column */
.nh-home .nh-news-row-date {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.nh-home .nh-news-row-year {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.82rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
}
.nh-home .nh-news-row-md {
	font-family: 'Cormorant Garamond', serif;
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--nh-green-dark);
	letter-spacing: 0.04em;
	margin-top: 2px;
}

/* Meta column (badges) */
.nh-home .nh-news-row-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	min-width: 0;
}
.nh-home .nh-news-new-badge {
	display: inline-block;
	padding: 3px 10px;
	background: #E74C3C;
	color: var(--nh-white);
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	border-radius: 2px;
	line-height: 1.3;
}

/* Body column */
.nh-home .nh-news-row-body {
	min-width: 0;
}
.nh-home .nh-news-row-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.02rem;
	font-weight: 600;
	color: var(--nh-text);
	line-height: 1.65;
	letter-spacing: 0.03em;
	margin: 0 0 6px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.nh-home .nh-news-row-excerpt {
	font-size: 0.85rem;
	color: var(--nh-text-muted);
	line-height: 1.65;
	letter-spacing: 0.03em;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Arrow */
.nh-home .nh-news-row-arrow {
	color: var(--nh-text-muted);
	transition: transform 0.3s var(--nh-ease), color 0.3s var(--nh-ease);
	display: flex;
	align-items: center;
}

/* Empty state */
.nh-home .nh-news-empty {
	text-align: center;
	padding: 80px 32px;
	color: var(--nh-text-muted);
	font-size: 0.95rem;
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	max-width: 960px;
	margin: 0 auto;
}

/* Pagination */
.nh-home .nh-news-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
	margin: 50px auto 0;
	flex-wrap: wrap;
	max-width: 960px;
}
.nh-home .nh-news-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	color: var(--nh-text);
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.95rem;
	letter-spacing: 0.06em;
	text-decoration: none;
	border-radius: var(--nh-radius-sm);
	transition: all 0.3s var(--nh-ease);
}
.nh-home .nh-news-pagination .page-numbers:hover {
	background: var(--nh-green);
	color: var(--nh-white);
	border-color: var(--nh-green);
	transform: translateY(-1px);
}
.nh-home .nh-news-pagination .page-numbers.current {
	background: var(--nh-green-dark);
	color: var(--nh-white);
	border-color: var(--nh-green-dark);
	font-weight: 500;
}
.nh-home .nh-news-pagination .page-numbers.dots {
	background: transparent;
	border: 0;
	color: var(--nh-text-muted);
}
.nh-home .nh-news-pagination .prev,
.nh-home .nh-news-pagination .next {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 0.85rem;
	padding: 0 16px;
}

/* ----- Responsive ----- */
@media (max-width: 768px) {
	.nh-home .nh-news-row {
		grid-template-columns: 88px 1fr 20px;
		gap: 14px;
		padding: 20px 20px;
	}
	.nh-home .nh-news-row-meta {
		grid-column: 2 / 3;
		grid-row: 1 / 2;
		margin-bottom: 4px;
	}
	.nh-home .nh-news-row-body {
		grid-column: 2 / 3;
		grid-row: 2 / 3;
	}
	.nh-home .nh-news-row-date {
		grid-column: 1 / 2;
		grid-row: 1 / 3;
		align-self: start;
		padding-top: 2px;
	}
	.nh-home .nh-news-row-arrow {
		grid-column: 3 / 4;
		grid-row: 1 / 3;
	}
	.nh-home .nh-news-row-md { font-size: 1.2rem; }
	.nh-home .nh-news-row-year { font-size: 0.72rem; }
	.nh-home .nh-news-row-title { font-size: 0.92rem; }
	.nh-home .nh-news-row-excerpt { font-size: 0.78rem; }
}
@media (max-width: 480px) {
	.nh-home .nh-news-pagination .page-numbers { min-width: 36px; height: 36px; padding: 0 10px; font-size: 0.85rem; }
	.nh-home .nh-news-pagination .prev,
	.nh-home .nh-news-pagination .next { padding: 0 12px; font-size: 0.78rem; }
}

/* ==============================================================
   16. Farm CPT List / Detail Styles
   ============================================================== */
.nh-home .nh-farm-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
}
.nh-home .nh-farm-card {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 0;
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	overflow: hidden;
	box-shadow: 0 8px 30px rgba(31, 63, 53, 0.06);
	transition: transform 0.4s var(--nh-ease), box-shadow 0.4s var(--nh-ease);
}
.nh-home .nh-farm-card:hover { transform: translateY(-3px); box-shadow: 0 16px 50px rgba(31, 63, 53, 0.1); }
.nh-home .nh-farm-card-visual {
	aspect-ratio: 4/3;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(47, 93, 78, 0.25);
}
.nh-home .nh-farm-status {
	position: absolute;
	top: 16px;
	left: 16px;
	padding: 5px 14px;
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	border-radius: 2px;
	color: var(--nh-white);
	font-weight: 500;
}
.nh-home .nh-farm-status-available { background: var(--nh-green); }
.nh-home .nh-farm-status-waiting { background: var(--nh-gold); }
.nh-home .nh-farm-status-closed { background: #888; }
.nh-home .nh-farm-card-body { padding: 40px 40px; display: flex; flex-direction: column; justify-content: center; }
.nh-home .nh-farm-card-eyebrow {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.85rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
	margin-bottom: 12px;
}
.nh-home .nh-farm-card-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--nh-green-dark);
	line-height: 1.5;
	letter-spacing: 0.04em;
	margin: 0 0 16px;
}
.nh-home .nh-farm-card-title a { color: inherit; text-decoration: none; transition: color 0.3s var(--nh-ease); }
.nh-home .nh-farm-card-title a:hover { color: var(--nh-green); }
.nh-home .nh-farm-card-intro { font-size: 0.9rem; line-height: 1.85; color: var(--nh-text-muted); margin: 0 0 24px; }

.nh-home .nh-farm-empty {
	text-align: center;
	padding: 80px 32px;
	color: var(--nh-text-muted);
	background: var(--nh-white);
	border-radius: var(--nh-radius);
	font-size: 0.95rem;
	line-height: 2;
}

/* Farm Detail Page */
.nh-home .nh-farm-detail-grid {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 60px;
	align-items: start;
}
.nh-home .nh-farm-detail-intro { padding-top: 20px; }
.nh-home .nh-farm-intro-text { font-size: 1rem; line-height: 2; color: var(--nh-text); margin: 0 0 24px; letter-spacing: 0.04em; }
.nh-home .nh-farm-detail-visual {
	aspect-ratio: 4/3;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	border-radius: var(--nh-radius);
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	color: rgba(47, 93, 78, 0.25);
	padding: 20px;
}
.nh-home .nh-farm-detail-caption {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.85rem;
	color: var(--nh-white);
	letter-spacing: 0.1em;
	text-shadow: 0 1px 8px rgba(0,0,0,0.4);
	position: absolute;
	bottom: 20px;
	left: 20px;
}
.nh-home .nh-farm-info-table-wrap { max-width: 900px; margin: 0 auto; }

@media (max-width: 960px) {
	.nh-home .nh-farm-card { grid-template-columns: 1fr; }
	.nh-home .nh-farm-card-body { padding: 32px 28px; }
	.nh-home .nh-farm-detail-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 640px) {
	.nh-home .nh-farm-card-body { padding: 28px 22px; }
	.nh-home .nh-farm-card-title { font-size: 1.2rem; }
	.nh-home .nh-farm-card-intro { font-size: 0.85rem; }
}

/* ==============================================================
   17. Footer Enhancements — License Detail Block + Affiliations
   ============================================================== */
#site-footer .nh-footer-brand-license {
	margin: 14px 0 0;
	padding: 0;
}
#site-footer .nh-footer-brand-license p {
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.55);
	margin: 0 0 4px;
	letter-spacing: 0.04em;
	line-height: 1.7;
}
#site-footer .nh-footer-brand-affil {
	margin-top: 16px;
	padding-top: 14px;
	border-top: 1px dashed rgba(255, 255, 255, 0.15);
}
#site-footer .nh-footer-brand-affil-label {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.72rem;
	color: var(--nh-gold-light);
	letter-spacing: 0.15em;
	margin-bottom: 6px;
	opacity: 0.85;
}
#site-footer .nh-footer-brand-affil ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
#site-footer .nh-footer-brand-affil li {
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.62);
	line-height: 1.85;
	letter-spacing: 0.04em;
}

/* ==============================================================
   18. SP Polish — Global fixes for readability
   ============================================================== */

/* --- Hamburger menu: reduce size --- */
@media (max-width: 768px) {
	/* オーバーレイメニュー: padding縮小、項目コンパクト化 */
	#site-header #global-nav,
	#site-header nav.global-nav,
	nav.nh-nav-mobile,
	#global-nav.nh-nav-mobile {
		padding: 70px 24px 40px !important;
	}
	#site-header .global-nav-list > li > a {
		padding: 14px 4px !important;
		font-size: 0.95rem !important;
		font-weight: 500 !important;
		letter-spacing: 0.08em !important;
	}
	#site-header .global-nav-list > li > a::before {
		font-size: 0.7rem !important;
		margin-right: 8px !important;
	}
	#site-header .global-nav-list > li > a::after {
		font-size: 0.9rem !important;
		right: 4px !important;
	}
	.nh-hamburger { width: 40px !important; height: 40px !important; }
	.nh-hamburger span { height: 1.5px !important; }
}

/* --- Blog Hero card SP fix (overflow, spacing) --- */
@media (max-width: 640px) {
	.nh-home .nh-blog-hero { padding: 10px 0 40px; }
	.nh-home .nh-blog-hero-card { border-radius: var(--nh-radius); box-shadow: 0 8px 30px rgba(31,63,53,0.08); }
	.nh-home .nh-blog-hero-visual { min-height: 200px; aspect-ratio: 16/10; }
	.nh-home .nh-blog-hero-body { padding: 28px 22px; }
	.nh-home .nh-blog-hero-date { font-size: 0.8rem; }
	.nh-home .nh-blog-hero-title { font-size: 1.15rem; line-height: 1.55; margin-bottom: 14px; }
	.nh-home .nh-blog-hero-excerpt { font-size: 0.82rem; margin-bottom: 20px; line-height: 1.85; }
	.nh-home .nh-blog-hero-meta { gap: 8px; }
	.nh-home .nh-blog-hero-arrow { font-size: 0.85rem; width: 100%; margin-left: 0; margin-top: 6px; text-align: right; }
}

/* --- Article main SP fixes (overflow-wrap) --- */
@media (max-width: 640px) {
	.nh-home .nh-article-main {
		box-shadow: 0 6px 24px rgba(31,63,53,0.06);
	}
	.nh-home .nh-article-hero-image { aspect-ratio: 4/3; }
	.nh-home .nh-article-header { padding: 28px 20px 22px; }
	.nh-home .nh-article-body {
		padding: 28px 20px;
		font-size: 0.92rem;
		line-height: 1.9;
		letter-spacing: 0.03em;
		overflow-wrap: break-word;
		word-break: normal;
	}
	.nh-home .nh-article-body h2 { font-size: 1.15rem; padding-left: 12px; border-left-width: 3px; margin: 2.4em 0 1em; }
	.nh-home .nh-article-body h3 { font-size: 1rem; margin: 2em 0 0.8em; }
	.nh-home .nh-article-body img { margin: 1.5em 0; }
	.nh-home .nh-article-body blockquote { padding: 16px 18px; font-size: 0.9rem; margin: 1.5em 0; }
	.nh-home .nh-article-footer { padding: 24px 20px 28px; }
	.nh-home .nh-article-tags,
	.nh-home .nh-article-share { gap: 10px; }
	.nh-home .nh-article-tags-label,
	.nh-home .nh-article-share-label { font-size: 0.75rem; }
}

/* --- News List SP overflow --- */
@media (max-width: 480px) {
	.nh-home .nh-news-list {
		border-radius: 0;
		margin: 0 -20px;
	}
	.nh-home .nh-news-row {
		padding: 18px 20px;
		gap: 12px;
	}
	.nh-home .nh-news-row-title,
	.nh-home .nh-news-row-excerpt {
		overflow-wrap: break-word;
		word-break: normal;
	}
}

/* --- Company section (Front Page) CTA breathing room --- */
@media (max-width: 960px) {
	.nh-home .nh-company-content {
		padding: 48px 32px 56px !important;
	}
}
@media (max-width: 640px) {
	.nh-home .nh-company-content {
		padding: 40px 24px 48px !important;
	}
	.nh-home .nh-company-content > .nh-btn,
	.nh-home .nh-company-content > a.nh-btn-ghost,
	.nh-home .nh-company-content > div:last-child {
		margin-top: 24px !important;
	}
}

/* --- Footer bottom leftover: hide ALL default Lightning bottom elements --- */
#site-footer > *:not(.nh-footer-info):not(.copyright-wrap) {
	/* NOTE: this hides Lightning's default nav/menu below our injected block */
}
#site-footer .footer-btm,
#site-footer .footer-bottom,
#site-footer .site-info-wrap,
#site-footer .footer-nav-wrap,
#site-footer nav[class*="footer"],
#site-footer .lightning-footer-nav,
#site-footer #footer-nav,
#site-footer > ul,
#site-footer > nav {
	display: none !important;
}

/* Affiliations list styling (会社概要ページ内) */
.nh-home .nh-affiliations-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.nh-home .nh-affiliations-list li {
	padding: 4px 0 4px 20px;
	line-height: 1.85;
	position: relative;
	color: var(--nh-text);
	font-size: 0.9rem;
}
.nh-home .nh-affiliations-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 14px;
	width: 12px;
	height: 1px;
	background: var(--nh-gold);
}

/* ==============================================================
   19. Front Page Company Teaser Fix (v0.15.3)
   image列が縦に引き伸ばされ、ボタンが見切れる問題の修正
   ============================================================== */
.nh-home .nh-company-grid {
	align-items: stretch;
	max-height: 560px;              /* セクション全体の高さを上限で抑える */
}
.nh-home .nh-company-image {
	aspect-ratio: auto;              /* stretch時にaspect-ratioは無効なので明示的にauto */
	min-height: 100%;
	max-height: 560px;
}
.nh-home .nh-company-content {
	padding: 48px 52px !important;   /* 64+88の上書きをリセット */
	justify-content: center;
	max-height: 560px;
	overflow: hidden;                /* 万一のはみ出しを防ぐ */
}
.nh-home .nh-company-quote {
	font-size: 1.3rem;
	line-height: 1.7;
	margin-bottom: 18px !important;
}
.nh-home .nh-company-text {
	font-size: 0.9rem;
	line-height: 1.9;
	margin-bottom: 24px !important;
}
.nh-home .nh-company-content > div:last-child,
.nh-home .nh-company-content > .nh-btn,
.nh-home .nh-company-content > a.nh-btn {
	margin-top: 0 !important;        /* 20px上書きをキャンセル */
}

/* Tablet */
@media (max-width: 960px) {
	.nh-home .nh-company-grid { max-height: none; }
	.nh-home .nh-company-image { max-height: 360px; min-height: 280px; }
	.nh-home .nh-company-content {
		max-height: none;
		padding: 40px 32px 48px !important;
	}
}

/* SP */
@media (max-width: 640px) {
	.nh-home .nh-company-image { max-height: 280px; min-height: 220px; aspect-ratio: 4/3; }
	.nh-home .nh-company-content { padding: 36px 24px 44px !important; }
	.nh-home .nh-company-quote { font-size: 1.2rem; line-height: 1.65; }
	.nh-home .nh-company-text { font-size: 0.88rem; line-height: 1.9; }
}

/* ==============================================================
   20. Lightning Footer 残置ナビ・装飾の完全除去 (v0.15.4)
   ============================================================== */
#site-footer nav.footer-nav,
#site-footer .footer-nav,
#site-footer .footer-nav-list,
footer.site-footer nav.footer-nav,
footer.site-footer .footer-nav,
.site-footer nav.footer-nav,
.site-footer .footer-nav {
	display: none !important;
	visibility: hidden !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
}

/* Lightning のフッター上部カラーバー / border 装飾を殺す */
#site-footer::after,
footer.site-footer::after,
.site-footer::after { content: none !important; display: none !important; }
#site-footer { border-top: 0 !important; }

/* copyright wrapper の余計な padding も念のためリセット */
#site-footer .site-footer-copyright,
#site-footer .container.site-footer-copyright {
	padding: 0 !important;
	margin: 0 !important;
}
#site-footer .site-footer-copyright p,
#site-footer .container.site-footer-copyright p {
	padding: 24px 32px !important;
	margin: 0 !important;
	text-align: center;
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.78rem !important;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.45) !important;
	background: rgba(0, 0, 0, 0.15);
	border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/* ==============================================================
   21. SP Hamburger Menu — Compact & Refined (v0.15.5)
   ============================================================== */
@media (max-width: 768px) {
	/* オーバーレイ本体: padding縮小、admin-bar分の余白確保 */
	#site-header #global-nav,
	#site-header nav.global-nav,
	nav.nh-nav-mobile,
	#global-nav.nh-nav-mobile {
		padding: 56px 24px 32px !important;
	}
	.admin-bar #site-header #global-nav,
	.admin-bar nav.nh-nav-mobile,
	.admin-bar #global-nav.nh-nav-mobile {
		padding-top: 80px !important;  /* admin bar 46px + ヘッダー分 */
	}

	/* リスト: 中央寄せ + 幅制限 */
	#site-header .global-nav-list,
	#site-header ul.global-nav-list,
	#site-header #global-nav ul {
		max-width: 360px !important;
		margin: 0 auto !important;
		gap: 0 !important;
	}

	/* 各項目: コンパクト化 */
	#site-header .global-nav-list > li {
		border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
	}
	#site-header .global-nav-list > li > a {
		padding: 14px 8px !important;
		font-size: 0.92rem !important;
		font-weight: 500 !important;
		letter-spacing: 0.06em !important;
		line-height: 1.4 !important;
	}
	#site-header .global-nav-list > li > a::before {
		font-size: 0.68rem !important;
		margin-right: 10px !important;
		letter-spacing: 0.12em !important;
	}
	#site-header .global-nav-list > li > a::after {
		font-size: 0.85rem !important;
		right: 4px !important;
		opacity: 0.4 !important;
	}

	/* ハンバーガー本体: 少し小さく */
	.nh-hamburger {
		width: 38px !important;
		height: 38px !important;
	}
	.nh-hamburger span {
		left: 9px !important;
		right: 9px !important;
	}
	.nh-hamburger span:nth-child(1) { top: 12px !important; }
	.nh-hamburger span:nth-child(2) { top: 18px !important; }
	.nh-hamburger span:nth-child(3) { top: 24px !important; }
	.nh-nav-open .nh-hamburger span:nth-child(1),
	.nh-nav-open .nh-hamburger span:nth-child(3) { top: 18px !important; }
}

/* 極小画面: さらに詰める */
@media (max-width: 380px) {
	#site-header #global-nav,
	nav.nh-nav-mobile,
	#global-nav.nh-nav-mobile {
		padding: 48px 20px 24px !important;
	}
	#site-header .global-nav-list > li > a {
		padding: 12px 6px !important;
		font-size: 0.88rem !important;
	}
}

/* 縦の短い画面（横向きスマホ等）用: 高さ足りない時のスクロール保証 */
@media (max-height: 600px) and (max-width: 768px) {
	#site-header #global-nav,
	nav.nh-nav-mobile,
	#global-nav.nh-nav-mobile {
		padding: 40px 24px 24px !important;
	}
	#site-header .global-nav-list > li > a {
		padding: 10px 8px !important;
		font-size: 0.88rem !important;
	}
}

/* ==============================================================
   22. Fallback templates: 404 / Search / Archive (v0.15.7)
   ★ style.css 末尾に追加。v0.15.6 で追加した同名セクションは削除して差し替え
   ============================================================== */

/* --nh-radius が :root 未定義なのでここで補う（既存の --nh-radius-md をエイリアス） */
:root {
	--nh-radius: 12px;
}

/* Lightning デフォルトサイドバーを非表示 */
body.error404 #main-section > .row > .col-sm-4,
body.error404 aside.sidebar,
body.error404 #sub-section,
body.search #main-section > .row > .col-sm-4,
body.search aside.sidebar,
body.search #sub-section,
body.archive #main-section > .row > .col-sm-4,
body.archive aside.sidebar,
body.archive #sub-section,
body.error404 .widget_recent_entries,
body.error404 .widget_categories,
body.error404 .widget_archive,
body.search .widget_recent_entries,
body.search .widget_categories,
body.search .widget_archive {
	display: none !important;
}
body.error404 #main-section > .row > .col-sm-8,
body.search #main-section > .row > .col-sm-8,
body.archive #main-section > .row > .col-sm-8 {
	width: 100% !important;
	max-width: 100% !important;
	flex: 0 0 100% !important;
}

/* ==============================================================
   404 page
   ============================================================== */
.nh-home .nh-notfound-actions {
	display: flex !important;
	gap: 16px;
	justify-content: center;
	margin-bottom: 80px;
	flex-wrap: wrap;
}
.nh-home .nh-notfound-links {
	background: var(--nh-beige-soft);
	border-radius: 12px;
	padding: 48px 40px;
}
.nh-home .nh-notfound-links-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	margin: 0 0 28px;
	letter-spacing: 0.06em;
	text-align: center;
}
.nh-home .nh-notfound-links-grid {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 16px !important;
}
.nh-home .nh-notfound-link {
	display: flex !important;
	flex-direction: column !important;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 24px 16px;
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	border-radius: 8px;
	text-align: center;
	text-decoration: none !important;
	transition: all 0.3s var(--nh-ease);
	min-height: 88px;
}
.nh-home .nh-notfound-link:hover {
	background: var(--nh-green);
	border-color: var(--nh-green);
	transform: translateY(-2px);
	box-shadow: var(--nh-shadow-md);
}
.nh-home .nh-notfound-link:hover .nh-notfound-link-en,
.nh-home .nh-notfound-link:hover .nh-notfound-link-ja {
	color: var(--nh-white);
}
.nh-home .nh-notfound-link-en {
	display: block !important;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.82rem;
	color: var(--nh-gold);
	letter-spacing: 0.15em;
	line-height: 1.3;
}
.nh-home .nh-notfound-link-ja {
	display: block !important;
	font-size: 0.92rem;
	font-weight: 500;
	color: var(--nh-green-dark);
	letter-spacing: 0.04em;
	line-height: 1.4;
}
@media (max-width: 640px) {
	.nh-home .nh-notfound-actions { flex-direction: column; gap: 12px; }
	.nh-home .nh-notfound-actions .nh-btn { width: 100%; justify-content: center; }
	.nh-home .nh-notfound-links { padding: 32px 20px; }
	.nh-home .nh-notfound-links-grid { grid-template-columns: 1fr 1fr !important; gap: 10px !important; }
	.nh-home .nh-notfound-link { padding: 18px 10px; min-height: 76px; }
}

/* ==============================================================
   Search results
   ============================================================== */
.nh-home .nh-search-results {
	display: flex;
	flex-direction: column;
	gap: 24px;
	max-width: 960px;
	margin: 0 auto;
}
.nh-home .nh-search-item {
	display: grid !important;
	grid-template-columns: 200px 1fr !important;
	gap: 28px !important;
	padding: 24px;
	background: var(--nh-white);
	border: 1px solid var(--nh-border);
	border-radius: 12px;
	transition: all 0.3s var(--nh-ease);
	text-decoration: none !important;
	color: inherit;
	align-items: center;
}
.nh-home .nh-search-item:hover {
	border-color: var(--nh-green-mist);
	box-shadow: var(--nh-shadow-md);
	transform: translateY(-2px);
}
.nh-home .nh-search-item:hover .nh-search-item-title { color: var(--nh-green); }
.nh-home .nh-search-item-thumb {
	aspect-ratio: 4/3;
	background-color: var(--nh-green-mist);
	background-size: cover;
	background-position: center;
	border-radius: var(--nh-radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(47, 93, 78, 0.25);
}
.nh-home .nh-search-item-body { min-width: 0; }
.nh-home .nh-search-item-type {
	display: inline-block;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 0.78rem;
	color: var(--nh-gold);
	letter-spacing: 0.12em;
	margin-bottom: 6px;
}
.nh-home .nh-search-item-title {
	font-family: 'Noto Serif JP', serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--nh-green-dark);
	line-height: 1.6;
	letter-spacing: 0.04em;
	margin: 0 0 8px;
	transition: color 0.3s var(--nh-ease);
}
.nh-home .nh-search-item-excerpt {
	font-size: 0.88rem;
	color: var(--nh-text-muted);
	line-height: 1.8;
	margin: 0 0 12px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.nh-home .nh-search-item-meta {
	font-family: 'Cormorant Garamond', serif;
	font-size: 0.82rem;
	color: var(--nh-gold);
	letter-spacing: 0.1em;
}
.nh-home .nh-search-empty {
	text-align: center;
	padding: 80px 32px;
	background: var(--nh-white);
	border-radius: 12px;
	color: var(--nh-text-muted);
	line-height: 2;
	max-width: 640px;
	margin: 0 auto;
}
@media (max-width: 640px) {
	.nh-home .nh-search-item {
		grid-template-columns: 100px 1fr !important;
		gap: 16px !important;
		padding: 16px;
	}
	.nh-home .nh-search-item-title { font-size: 0.95rem; }
	.nh-home .nh-search-item-excerpt { display: none; }
}

/* ==============================================================
   23. Article breadcrumb layout fix (v0.15.8)
   single.php のパンくずが見切れる問題の修正
   style.css 末尾に追加
   ============================================================== */

.nh-home .nh-article-crumb {
	background: var(--nh-beige);
	padding: 20px 0;
	border-bottom: 1px solid var(--nh-border);
	width: 100%;
	box-sizing: border-box;
}
.nh-home .nh-article-crumb > .nh-container,
.nh-home .nh-article-crumb .nh-breadcrumb-inner {
	max-width: var(--nh-container);
	margin: 0 auto;
	padding: 0 32px;
	box-sizing: border-box;
}
/* 中身が nh-container で包まれてない場合の直接指定フォールバック */
.nh-home .nh-article-crumb .nh-breadcrumb {
	max-width: var(--nh-container);
	margin: 0 auto;
	padding: 0 32px;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 0;
	font-size: 0.82rem;
	color: var(--nh-text-muted);
	letter-spacing: 0.04em;
	line-height: 1.6;
}
.nh-home .nh-article-crumb .nh-breadcrumb a,
.nh-home .nh-article-crumb .nh-breadcrumb span {
	display: inline;
	max-width: none;
	overflow: visible;
	text-overflow: initial;
	white-space: normal;
}
.nh-home .nh-article-crumb .nh-crumb-sep {
	margin: 0 10px;
	color: var(--nh-gold);
	font-family: 'Cormorant Garamond', serif;
	flex-shrink: 0;
}

/* Lightning のメインラッパが max-width を絞ってる場合の解除（single/archive/search共通） */
body.single #main-section,
body.single .site-body,
body.single .l-container,
body.single #main-section > .container,
body.single #main-section > .l-container {
	max-width: 100% !important;
	width: 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
body.single #main-section > .row > .col-sm-4,
body.single aside.sidebar,
body.single #sub-section {
	display: none !important;
}
body.single #main-section > .row > .col-sm-8 {
	width: 100% !important;
	max-width: 100% !important;
	flex: 0 0 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
body.single #main-section > .row {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* SP */
@media (max-width: 640px) {
	.nh-home .nh-article-crumb { padding: 14px 0; }
	.nh-home .nh-article-crumb .nh-breadcrumb {
		padding: 0 20px;
		font-size: 0.75rem;
	}
	.nh-home .nh-article-crumb .nh-crumb-sep { margin: 0 6px; }
	/* SPで長いタイトルは省略 */
	.nh-home .nh-article-crumb .nh-crumb-current {
		display: inline-block;
		max-width: 60%;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		vertical-align: bottom;
	}
}

/* ==============================================================
   24. Single Post Layout — Lightning wrapper reset (v0.15.9)
   ★ v0.15.8 の Section 23（.nh-article-crumb padding修正）は残してOK。
     このセクションは Lightning ラッパの幅制限を根本的にリセットするもの。
   ============================================================== */

/* body.single 時に Lightning のあらゆる幅制限ラッパを解除 */
body.single #main-section,
body.single .site-body,
body.single .l-container,
body.single .container,
body.single #main-section > .container,
body.single #main-section > .l-container,
body.single #main-section > .row,
body.single .main-section-inner,
body.single main.site-body-main,
body.single main,
body.archive #main-section,
body.archive .site-body,
body.archive .l-container,
body.archive #main-section > .container,
body.archive #main-section > .l-container,
body.archive #main-section > .row,
body.search #main-section,
body.search .site-body,
body.search .l-container,
body.search #main-section > .container,
body.search #main-section > .l-container,
body.search #main-section > .row,
body.error404 #main-section,
body.error404 .site-body,
body.error404 .l-container,
body.error404 #main-section > .container,
body.error404 #main-section > .l-container,
body.error404 #main-section > .row {
	max-width: 100% !important;
	width: 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	overflow: visible !important;
}

/* サイドバー完全非表示 & メインカラム100% */
body.single aside.sidebar,
body.single #sub-section,
body.single #main-section > .row > .col-sm-4,
body.archive aside.sidebar,
body.archive #sub-section,
body.archive #main-section > .row > .col-sm-4,
body.search aside.sidebar,
body.search #sub-section,
body.search #main-section > .row > .col-sm-4,
body.error404 aside.sidebar,
body.error404 #sub-section,
body.error404 #main-section > .row > .col-sm-4 {
	display: none !important;
}
body.single #main-section > .row > .col-sm-8,
body.archive #main-section > .row > .col-sm-8,
body.search #main-section > .row > .col-sm-8,
body.error404 #main-section > .row > .col-sm-8 {
	width: 100% !important;
	max-width: 100% !important;
	flex: 0 0 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Lightning の single ページ用 page-header を完全に消す */
body.single .page-header,
body.single header.page-header,
body.single section.page-header,
body.single .entry-header:not(.nh-article-header),
body.single .entry-meta,
body.single .lightning-page-header,
body.single .vk-page-header {
	display: none !important;
}

/* .nh-home 自体は幅制限を受けないように */
body.single .nh-home,
body.archive .nh-home,
body.search .nh-home,
body.error404 .nh-home {
	width: 100%;
	max-width: 100%;
	overflow-x: hidden;  /* fullwidth が -50vw する時のはみ出しをクリップ */
}

/* .nh-fullwidth を single 系でも正しく動作させる */
body.single .nh-home .nh-fullwidth,
body.archive .nh-home .nh-fullwidth,
body.search .nh-home .nh-fullwidth,
body.error404 .nh-home .nh-fullwidth {
	width: 100vw !important;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	max-width: 100vw !important;
}

/* ==============================================================
   25. Sticky Header Fix — overflow-x を .nh-home から外す (v0.15.10)
   ★ v0.15.9 の overflow-x: hidden 指定が sticky ヘッダーを壊していた
     ので撤回し、body 側で clip する
   ============================================================== */

/* v0.15.9 の overflow-x: hidden を撤回 */
body.single .nh-home,
body.archive .nh-home,
body.search .nh-home,
body.error404 .nh-home {
	overflow-x: visible !important;
	overflow-y: visible !important;
}

/* 代わりに body / html でクリップ（overflow-x: clip は sticky を壊さない） */
html,
body {
	overflow-x: clip;
}
/* clip 非対応ブラウザ用のフォールバック */
@supports not (overflow-x: clip) {
	html, body { overflow-x: hidden; }
}

/* Lightning が single 系ページでコンテンツラッパに overflow を掛けている場合の解除 */
body.single #main-section,
body.single #main-section > .row,
body.single .site-body,
body.single main,
body.archive #main-section,
body.archive #main-section > .row,
body.search #main-section,
body.search #main-section > .row,
body.error404 #main-section,
body.error404 #main-section > .row {
	overflow: visible !important;
	overflow-x: visible !important;
	overflow-y: visible !important;
}

/* パンくずセクションを他ページのページヘッダーと同等の余白に整える */
.nh-home .nh-article-crumb {
	padding: 24px 0;
}
.nh-home .nh-article-crumb .nh-breadcrumb {
	max-width: var(--nh-container);
	margin: 0 auto;
	padding: 0 32px;
	box-sizing: border-box;
	font-size: 0.85rem;
	color: var(--nh-text-muted);
	letter-spacing: 0.04em;
	line-height: 1.6;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}

/* SP */
@media (max-width: 640px) {
	.nh-home .nh-article-crumb { padding: 16px 0; }
	.nh-home .nh-article-crumb .nh-breadcrumb { padding: 0 20px; font-size: 0.78rem; }
}

/* ==============================================================
   26. Article breadcrumb — Visual breathing room (v0.15.11)
   site-header sticky と パンくずの視覚的な境界を明確に
   ============================================================== */

/* パンくずセクションを厚めに + 背景を少しはっきり */
.nh-home .nh-article-crumb {
	padding: 32px 0 !important;
	background: var(--nh-beige) !important;
	border-top: 1px solid var(--nh-border);
	border-bottom: 1px solid var(--nh-border);
	position: relative;
	z-index: 1;
}

/* site-header に下端の影を強めて、コンテンツとの境界を作る */
#site-header {
	box-shadow: 0 2px 12px rgba(31, 63, 53, 0.06) !important;
}

/* SP */
@media (max-width: 640px) {
	.nh-home .nh-article-crumb {
		padding: 20px 0 !important;
	}
}

/* もし .nh-home の直前で余白がない場合の保険 */
body.single .nh-home > *:first-child,
body.archive .nh-home > *:first-child,
body.search .nh-home > *:first-child,
body.error404 .nh-home > *:first-child {
	margin-top: 0;
}

/* ==============================================================
   27. WPForms Styling — nh-home theme integration (v0.15.12)
   お問合せフォームを nh-home デザインに統合
   style.css 末尾に追加
   ============================================================== */

/* WPForms コンテナを幅いっぱいに */
.nh-home .wpforms-container,
.nh-home div.wpforms-container-full {
	max-width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}
.nh-home .wpforms-container form.wpforms-form {
	max-width: 100% !important;
}

/* フィールドラッパ */
.nh-home .wpforms-field {
	padding: 0 0 24px !important;
	margin: 0 !important;
}

/* ラベル */
.nh-home .wpforms-field-label,
.nh-home .wpforms-field label.wpforms-field-label {
	font-family: 'Noto Sans JP', sans-serif !important;
	font-size: 0.9rem !important;
	font-weight: 500 !important;
	color: var(--nh-green-dark) !important;
	letter-spacing: 0.06em !important;
	margin-bottom: 10px !important;
	display: block !important;
}

/* 必須マーク */
.nh-home .wpforms-required-label {
	color: #C2554F !important;
	font-size: 0.72rem !important;
	background: #FBE9E7 !important;
	padding: 3px 10px !important;
	margin-left: 10px !important;
	border-radius: 3px !important;
	font-weight: 500 !important;
	letter-spacing: 0.08em !important;
	vertical-align: middle !important;
}

/* 入力欄 全種類 */
.nh-home .wpforms-field input[type="text"],
.nh-home .wpforms-field input[type="email"],
.nh-home .wpforms-field input[type="tel"],
.nh-home .wpforms-field input[type="url"],
.nh-home .wpforms-field input[type="number"],
.nh-home .wpforms-field input[type="password"],
.nh-home .wpforms-field select,
.nh-home .wpforms-field textarea {
	width: 100% !important;
	max-width: 100% !important;
	padding: 14px 18px !important;
	border: 1px solid var(--nh-border) !important;
	border-radius: var(--nh-radius-sm) !important;
	font-family: 'Noto Sans JP', sans-serif !important;
	font-size: 0.95rem !important;
	background: var(--nh-white) !important;
	color: var(--nh-text) !important;
	transition: border-color 0.3s var(--nh-ease), box-shadow 0.3s var(--nh-ease) !important;
	box-shadow: none !important;
	line-height: 1.6 !important;
	height: auto !important;
	box-sizing: border-box !important;
}

/* フォーカス時 */
.nh-home .wpforms-field input[type="text"]:focus,
.nh-home .wpforms-field input[type="email"]:focus,
.nh-home .wpforms-field input[type="tel"]:focus,
.nh-home .wpforms-field input[type="url"]:focus,
.nh-home .wpforms-field input[type="number"]:focus,
.nh-home .wpforms-field input[type="password"]:focus,
.nh-home .wpforms-field select:focus,
.nh-home .wpforms-field textarea:focus {
	outline: none !important;
	border-color: var(--nh-green) !important;
	box-shadow: 0 0 0 3px rgba(47, 93, 78, 0.08) !important;
}

/* textarea */
.nh-home .wpforms-field textarea {
	min-height: 160px !important;
	resize: vertical !important;
}

/* select */
.nh-home .wpforms-field select {
	appearance: none !important;
	-webkit-appearance: none !important;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%232F5D4E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
	background-repeat: no-repeat !important;
	background-position: right 18px center !important;
	padding-right: 44px !important;
	cursor: pointer !important;
}

/* ラジオ・チェックボックス */
.nh-home .wpforms-field-radio ul,
.nh-home .wpforms-field-checkbox ul {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
.nh-home .wpforms-field-radio li,
.nh-home .wpforms-field-checkbox li {
	margin-bottom: 10px !important;
	padding: 0 !important;
}
.nh-home .wpforms-field-radio label,
.nh-home .wpforms-field-checkbox label {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	font-size: 0.9rem !important;
	color: var(--nh-text) !important;
	cursor: pointer !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* 説明テキスト */
.nh-home .wpforms-field-description,
.nh-home .wpforms-field-sublabel {
	font-size: 0.82rem !important;
	color: var(--nh-text-muted) !important;
	margin-top: 8px !important;
	line-height: 1.7 !important;
}

/* 送信ボタン */
.nh-home .wpforms-field-container + .wpforms-submit-container,
.nh-home .wpforms-submit-container {
	padding: 16px 0 0 !important;
	margin: 0 !important;
	text-align: center !important;
}
.nh-home button.wpforms-submit,
.nh-home .wpforms-submit-container button[type="submit"] {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 12px !important;
	padding: 18px 48px !important;
	font-family: 'Noto Sans JP', sans-serif !important;
	font-size: 0.95rem !important;
	font-weight: 500 !important;
	letter-spacing: 0.08em !important;
	background: var(--nh-green) !important;
	color: var(--nh-white) !important;
	border: none !important;
	border-radius: var(--nh-radius-sm) !important;
	cursor: pointer !important;
	transition: all 0.3s var(--nh-ease) !important;
	box-shadow: none !important;
	line-height: 1 !important;
	text-transform: none !important;
	min-width: 220px !important;
}
.nh-home button.wpforms-submit:hover,
.nh-home .wpforms-submit-container button[type="submit"]:hover {
	background: var(--nh-green-dark) !important;
	color: var(--nh-white) !important;
	transform: translateY(-2px) !important;
	box-shadow: var(--nh-shadow-md) !important;
}

/* エラー表示 */
.nh-home .wpforms-error,
.nh-home label.wpforms-error {
	color: #C2554F !important;
	font-size: 0.82rem !important;
	margin-top: 6px !important;
	padding: 4px 0 !important;
	background: transparent !important;
	border: none !important;
}
.nh-home input.wpforms-error,
.nh-home select.wpforms-error,
.nh-home textarea.wpforms-error {
	border-color: #C2554F !important;
}

/* 送信完了メッセージ */
.nh-home .wpforms-confirmation-container-full,
.nh-home div.wpforms-confirmation-container-full {
	background: var(--nh-beige-soft) !important;
	border: 1px solid var(--nh-green-mist) !important;
	color: var(--nh-green-dark) !important;
	padding: 24px 28px !important;
	border-radius: var(--nh-radius-md) !important;
	font-size: 0.95rem !important;
	line-height: 1.9 !important;
	margin: 0 !important;
}

/* フォーム外側の変な白背景・枠を消す */
.nh-home #wpforms-74,
.nh-home form.wpforms-form {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	padding: 0 !important;
}

/* SP */
@media (max-width: 640px) {
	.nh-home .wpforms-field { padding-bottom: 20px !important; }
	.nh-home .wpforms-field input[type="text"],
	.nh-home .wpforms-field input[type="email"],
	.nh-home .wpforms-field input[type="tel"],
	.nh-home .wpforms-field select,
	.nh-home .wpforms-field textarea {
		padding: 12px 14px !important;
		font-size: 0.92rem !important;
	}
	.nh-home .wpforms-field textarea { min-height: 140px !important; }
	.nh-home button.wpforms-submit {
		width: 100% !important;
		padding: 16px 24px !important;
	}
}