/*
Theme Name: Lightning Child
Theme URI: 
Template: lightning
Description: Netsu Housing custom design built on Lightning
Author: 
Tags: 
Version: 0.10.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; display: flex; flex-direction: column; justify-content: center; }
.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
   ============================================================== */
@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; }
}
@media (max-width: 640px) {
  .nh-home .nh-container { padding: 0 20px; }
  .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; }
  .nh-home .nh-hero { min-height: 60vh; }
  .nh-home .nh-area-stats { grid-template-columns: 1fr 1fr; }
  .nh-home .nh-section, .nh-home .nh-section-alt, .nh-home .nh-section-dark { padding: 70px 0; }
  .nh-home .nh-page-header { padding: 70px 0 50px; }
  .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: 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;
}
#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;
}
#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 {
	display: block;
	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;
	position: relative;
	white-space: nowrap;
	transition: color 0.3s var(--nh-ease);
}
#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: flex;
	align-items: center;
	gap: 10px;
	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);
	flex-shrink: 0;
}
.nh-header-cta:hover { background: var(--nh-green-dark); color: var(--nh-white) !important; }
.nh-header-cta-icon { display: flex; align-items: center; }
.nh-header-cta-text { display: flex; flex-direction: column; line-height: 1.2; }
.nh-header-cta-label { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 0.7rem; letter-spacing: 0.1em; color: rgba(255,255,255,0.7); }
.nh-header-cta-number { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; letter-spacing: 0.04em; font-weight: 500; }

@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: 10px; }
}
@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; }
}