/* ===== なごみペイント サブページ共通 ===== */
.nagomi-subpage{font-family:'Zen Maru Gothic','Noto Sans JP',sans-serif;color:#2A2520;background:#FAF8F5;line-height:1.9;-webkit-font-smoothing:antialiased}
.nagomi-subpage *{box-sizing:border-box}
.nagomi-subpage img{max-width:100%;display:block}
.nagomi-subpage a{color:inherit;text-decoration:none}
.sp-inner{max-width:1200px;margin:0 auto;padding:0 32px}
.nagomi-subpage .sec-label{font-family:'Inter',sans-serif;font-size:.68rem;font-weight:600;color:#A89E94;letter-spacing:5px;text-transform:uppercase;margin-bottom:16px;display:block}
.nagomi-subpage .sp-h2{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:900;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid #2E8B6A;display:inline-block}

/* Hero */
.subpage-hero{padding:120px 0 60px;background:linear-gradient(135deg,#FFFCF7 0%,#F3F0EB 100%);border-bottom:1px solid rgba(0,0,0,.05)}
.subpage-hero h1{font-size:clamp(1.8rem,4vw,3rem);font-weight:900;line-height:1.4;margin-bottom:16px}
.subpage-hero p{color:#7A7268;font-size:.95rem}
.back-link{display:inline-block;font-size:.78rem;color:#7A7268;margin-bottom:24px;font-family:'Inter',sans-serif;letter-spacing:.5px}
.back-link:hover{color:#2E8B6A}

/* Case Filter */
.case-filter-bar{padding:32px 0;background:#fff;border-bottom:1px solid rgba(0,0,0,.05);position:sticky;top:0;z-index:10}
.cf-list{display:flex;flex-wrap:wrap;gap:10px}
.cf-item{padding:10px 22px;border-radius:100px;background:#F3F0EB;font-size:.82rem;font-weight:600;transition:all .3s cubic-bezier(.22,1,.36,1);font-family:'Noto Sans JP',sans-serif}
.cf-item:hover{background:#E8E4DE}
.cf-item.active{background:#2E8B6A;color:#fff}

/* Case Grid */
.case-grid-sec{padding:80px 0}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.case-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px rgba(58,53,48,.04);transition:all .5s cubic-bezier(.22,1,.36,1)}
.case-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(58,53,48,.1)}
.cc-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#F3F0EB}
.cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.case-card:hover .cc-img img{transform:scale(1.05)}
.cc-tag{position:absolute;top:14px;left:14px;background:rgba(46,139,106,.92);color:#fff;padding:5px 14px;border-radius:4px;font-size:.68rem;font-weight:700;letter-spacing:1px;font-family:'Inter',sans-serif}
.cc-body{padding:24px 26px}
.cc-body h3{font-size:1rem;font-weight:700;margin-bottom:8px;line-height:1.5}
.cc-meta{font-size:.75rem;color:#A89E94;margin-bottom:10px;font-family:'Noto Sans JP',sans-serif}
.cc-highlight{font-size:.82rem;color:#7A7268;line-height:1.8}

/* Pagination */
.case-pager{margin-top:60px;text-align:center}
.case-pager .page-numbers{display:inline-block;padding:10px 16px;margin:0 3px;background:#fff;border-radius:8px;color:#7A7268;font-size:.85rem;font-weight:700;font-family:'Inter',sans-serif;transition:all .3s}
.case-pager .page-numbers:hover,.case-pager .page-numbers.current{background:#2E8B6A;color:#fff}
.case-pager .page-numbers.dots{background:transparent}

/* Single Case */
.case-single .cs-tags{display:flex;gap:8px;margin-bottom:12px}
.case-single .cs-tag{background:rgba(46,139,106,.12);color:#2E8B6A;padding:4px 12px;border-radius:4px;font-size:.7rem;font-weight:700}
.case-single .cs-address{color:#7A7268;font-size:.9rem;margin-top:8px}

.cs-ba-sec{padding:60px 0;background:#fff}
.cs-ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cs-ba-item{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;background:#F3F0EB}
.cs-ba-item img{width:100%;height:100%;object-fit:cover}
.cs-ba-lb{position:absolute;top:14px;left:14px;padding:6px 18px;color:#fff;font-size:.7rem;font-weight:800;border-radius:4px;letter-spacing:2px;font-family:'Inter',sans-serif}
.cs-ba-lb.before{background:rgba(42,37,32,.9)}
.cs-ba-lb.after{background:rgba(46,139,106,.95)}

.cs-spec-sec{padding:80px 0}
.cs-spec{background:#fff;border-radius:16px;padding:8px 32px}
.cs-spec-row{display:grid;grid-template-columns:180px 1fr;padding:20px 0;border-bottom:1px solid rgba(0,0,0,.06);font-size:.88rem}
.cs-spec-row:last-child{border-bottom:none}
.cs-spec-label{color:#7A7268;font-weight:700}
.cs-spec-val{color:#2A2520}

.cs-comment-sec{padding:0 0 80px}
.cs-comment{background:#fff;border-radius:16px;padding:40px;font-size:.92rem;line-height:2.2}

.cs-gallery-sec{padding:0 0 80px}
.cs-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cs-gal-item{aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:#F3F0EB}
.cs-gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cs-gal-item:hover img{transform:scale(1.05)}

.cs-voice-sec{padding:0 0 80px}
.cs-voice{background:linear-gradient(135deg,#FFFCF7,#F3F0EB);border-radius:16px;padding:40px;border-left:4px solid #C88B2E}
.cs-voice-stars{color:#E8AD4A;font-size:1.1rem;margin-bottom:16px;letter-spacing:2px}
.cs-voice-text{font-family:'Noto Serif JP',serif;font-size:1rem;line-height:2.2;color:#2A2520;margin-bottom:16px}
.cs-voice-author{color:#7A7268;font-size:.82rem;font-weight:700}

/* Voice archive */
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:60px 0}
.voice-card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px rgba(58,53,48,.04);transition:box-shadow .4s}
.voice-card:hover{box-shadow:0 12px 40px rgba(58,53,48,.08)}
.voice-head{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.voice-photo{width:60px;height:60px;border-radius:50%;background:#F3F0EB;display:flex;align-items:center;justify-content:center;font-weight:700;color:#2E8B6A;font-size:1.2rem;overflow:hidden}
.voice-photo img{width:100%;height:100%;object-fit:cover}
.voice-head-info h4{font-size:.95rem;font-weight:700}
.voice-head-info p{font-size:.72rem;color:#A89E94;margin-top:2px}
.voice-card-stars{color:#E8AD4A;letter-spacing:1px;margin-bottom:10px;font-size:.85rem}
.voice-card-text{font-size:.88rem;line-height:2;color:#5A5248}

/* CTA */
.subpage-cta{padding:80px 0;background:#2A2520;color:#fff;text-align:center}
.subpage-cta h2{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:900;margin-bottom:16px;line-height:1.5}
.subpage-cta p{color:rgba(255,255,255,.6);margin-bottom:32px;font-size:.9rem}
.btn-main-g{display:inline-flex;align-items:center;gap:8px;padding:16px 40px;background:#2E8B6A;color:#fff;font-size:.9rem;font-weight:700;border-radius:6px;transition:all .4s cubic-bezier(.22,1,.36,1)}
.btn-main-g:hover{background:#4DB88C;transform:translateY(-2px);box-shadow:0 8px 24px rgba(46,139,106,.4)}

.no-results{text-align:center;padding:60px 0;color:#7A7268}

/* ===== SERVICE DETAIL PAGE ===== */
.service-page .sv-hero{padding:180px 0 100px;color:#fff;background:#2A2520}
.service-page .sv-hero .sv-label{color:rgba(255,255,255,.5)}
.service-page .sv-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.8rem);margin-bottom:16px}
.sv-catch{color:rgba(255,255,255,.8);font-family:'Noto Serif JP',serif;font-size:clamp(1rem,1.4vw,1.2rem);font-style:italic}

.sv-intro-sec{padding:100px 0;background:#fff}
.sv-intro{max-width:800px;margin:0 auto;font-size:1rem;line-height:2.2;color:#2A2520}
.sv-intro p{margin-bottom:20px}

.sv-feat-sec{padding:100px 0;background:#FAF8F5}
.sv-feat-grid{display:grid;gap:24px;margin-top:48px}
.sv-feat-grid.cols-1{grid-template-columns:1fr}
.sv-feat-grid.cols-2{grid-template-columns:1fr 1fr}
.sv-feat-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.sv-feat-grid.cols-4{grid-template-columns:repeat(2,1fr)}
.sv-feat-card{background:#fff;border-radius:16px;padding:40px 32px;box-shadow:0 4px 20px rgba(58,53,48,.04);transition:transform .4s}
.sv-feat-card:hover{transform:translateY(-4px)}
.sv-feat-num{font-family:'Inter',sans-serif;font-size:2.2rem;font-weight:900;color:#2E8B6A;line-height:1;margin-bottom:16px}
.sv-feat-card h3{font-size:1.05rem;font-weight:700;margin-bottom:12px;line-height:1.5}
.sv-feat-card p{font-size:.85rem;color:#5A5248;line-height:2}

.sv-check-sec{padding:100px 0;background:#fff}
.sv-checklist{max-width:720px;margin:32px auto 0;list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sv-checklist li{display:flex;align-items:center;gap:14px;padding:18px 24px;background:#FAF8F5;border-radius:10px;font-size:.9rem;font-weight:600;color:#2A2520}
.chk-ic{width:24px;height:24px;background:#2E8B6A;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:900;flex-shrink:0}

.sv-price-sec{padding:100px 0;background:#FAF8F5}
.sv-price-grid{display:grid;gap:20px;margin-top:48px}
.sv-price-grid.cols-1{grid-template-columns:1fr}
.sv-price-grid.cols-2{grid-template-columns:1fr 1fr;max-width:800px;margin-left:auto;margin-right:auto}
.sv-price-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.sv-price-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.sv-price-card{position:relative;background:#fff;border-radius:16px;padding:32px 24px;text-align:center;border:2px solid transparent;transition:all .4s}
.sv-price-card.recommended{border-color:#C88B2E;transform:scale(1.03);box-shadow:0 20px 50px rgba(200,139,46,.15)}
.sv-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:#C88B2E;color:#fff;padding:5px 18px;border-radius:100px;font-size:.68rem;font-weight:700;letter-spacing:1px;font-family:'Noto Sans JP',sans-serif}
.sv-price-card h3{font-size:.95rem;font-weight:700;margin-bottom:16px;line-height:1.5}
.sv-price-range{font-family:'Inter',sans-serif;font-size:1.6rem;font-weight:900;color:#2E8B6A;line-height:1.2;margin-bottom:8px}
.sv-price-life{font-size:.72rem;color:#A89E94;margin-bottom:16px;font-family:'Noto Sans JP',sans-serif;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.06)}
.sv-price-desc{font-size:.78rem;color:#5A5248;line-height:1.9;text-align:left}
.sv-price-note{max-width:720px;margin:32px auto 0;padding:16px 20px;background:rgba(200,139,46,.08);border-left:3px solid #C88B2E;font-size:.78rem;color:#5A5248;line-height:1.8;border-radius:6px}

.sv-cases-sec{padding:100px 0;background:#fff}
.sv-cases-sec .case-grid{grid-template-columns:repeat(4,1fr)}

.sv-faq-sec{padding:100px 0;background:#FAF8F5}
.sv-faq-list{max-width:800px;margin:40px auto 0;display:flex;flex-direction:column;gap:12px}
.sv-faq-item{background:#fff;border-radius:12px;padding:22px 28px;cursor:pointer;transition:box-shadow .3s}
.sv-faq-item:hover{box-shadow:0 4px 20px rgba(58,53,48,.06)}
.sv-faq-q{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:.9rem;gap:16px}
.sv-faq-ic{font-size:1.3rem;color:#A89E94;transition:transform .3s;flex-shrink:0}
.sv-faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:#5A5248;font-size:.82rem;line-height:2}
.sv-faq-a p{padding-top:14px}
.sv-faq-item.open .sv-faq-a{max-height:400px}
.sv-faq-item.open .sv-faq-ic{transform:rotate(45deg);color:#2E8B6A}

.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:transparent;border:1px solid #2A2520;color:#2A2520;font-size:.85rem;font-weight:700;border-radius:4px;transition:all .4s}
.btn-outline:hover{background:#2A2520;color:#fff}

/* Service responsive */
@media(max-width:1024px){
  .sv-feat-grid.cols-3,.sv-feat-grid.cols-4{grid-template-columns:1fr 1fr}
  .sv-price-grid.cols-3,.sv-price-grid.cols-4{grid-template-columns:1fr 1fr}
  .sv-price-card.recommended{transform:none}
  .sv-cases-sec .case-grid{grid-template-columns:repeat(2,1fr)}
  .sv-checklist{grid-template-columns:1fr}
}
@media(max-width:768px){
  .service-page .sv-hero{padding:120px 0 60px}
  .sv-feat-grid.cols-2,.sv-feat-grid.cols-3,.sv-feat-grid.cols-4{grid-template-columns:1fr}
  .sv-price-grid.cols-2,.sv-price-grid.cols-3,.sv-price-grid.cols-4{grid-template-columns:1fr}
  .sv-cases-sec .case-grid{grid-template-columns:1fr}
}

/* Responsive */
@media(max-width:1024px){
  .case-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .voice-grid{grid-template-columns:1fr}
  .cs-gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .sp-inner{padding:0 20px}
  .subpage-hero{padding:90px 0 40px}
  .case-grid{grid-template-columns:1fr;gap:20px}
  .cs-ba-grid{grid-template-columns:1fr}
  .cs-spec-row{grid-template-columns:1fr;gap:4px}
  .cs-spec-label{color:#A89E94;font-size:.75rem}
  .cs-gallery-grid{grid-template-columns:1fr}
  .cf-list{gap:6px}
  .cf-item{padding:8px 16px;font-size:.75rem}
  /* Case filter bar: allow horizontal scroll instead of wrap */
  .case-filter-bar{padding:20px 0}
  .cf-list{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 20px;margin:0 -20px}
  .cf-list::-webkit-scrollbar{display:none}
  .cf-item{flex-shrink:0}
  /* Voice */
  .voice-card{padding:24px}
  .voice-head{gap:12px}
  .voice-photo{width:48px;height:48px;font-size:1rem}
  /* Single case */
  .cs-comment,.cs-voice{padding:28px 22px}
  .cs-voice-text{font-size:.92rem;line-height:2}
  /* Service */
  .sv-feat-card{padding:28px 22px}
  .sv-price-card{padding:24px 18px}
  .sv-price-range{font-size:1.4rem}
  .sv-intro{font-size:.9rem;line-height:2}
  .sv-intro-sec,.sv-feat-sec,.sv-check-sec,.sv-price-sec,.sv-cases-sec,.sv-faq-sec{padding:60px 0}
}

/* ===== SMALL PHONES (subpage) ===== */
@media(max-width:600px){
  .sp-inner{padding:0 16px}
  .subpage-hero{padding:84px 0 36px}
  .subpage-hero h1{font-size:clamp(1.5rem,6vw,2rem);line-height:1.5}
  .subpage-hero p{font-size:.82rem}
  .back-link{font-size:.72rem;margin-bottom:16px}
  .sp-h2{font-size:clamp(1.15rem,5vw,1.5rem);margin-bottom:24px;padding-bottom:12px}
  /* Case grid / cards */
  .case-grid-sec{padding:48px 0}
  .cc-body{padding:20px 22px}
  .cc-body h3{font-size:.95rem}
  /* BA */
  .cs-ba-sec{padding:40px 0}
  .cs-ba-grid{gap:16px}
  /* Spec/comment/gallery */
  .cs-spec-sec,.cs-comment-sec,.cs-gallery-sec,.cs-voice-sec{padding:0 0 48px}
  .cs-spec{padding:4px 22px}
  .cs-spec-row{padding:14px 0;font-size:.82rem}
  .cs-comment{padding:24px 20px;font-size:.86rem;line-height:2}
  .cs-voice{padding:24px 20px;border-left-width:3px}
  .cs-voice-stars{font-size:1rem;margin-bottom:12px}
  .cs-voice-text{font-size:.88rem;line-height:1.9;margin-bottom:12px}
  /* Voice archive */
  .voice-grid{padding:40px 0;gap:16px}
  .voice-card{padding:22px 20px}
  .voice-card-text{font-size:.82rem;line-height:1.9}
  /* CTA */
  .subpage-cta{padding:56px 20px}
  .subpage-cta h2{font-size:clamp(1.15rem,5vw,1.5rem)}
  .subpage-cta p{font-size:.82rem;margin-bottom:24px}
  .btn-main-g{padding:14px 28px;font-size:.85rem}
  /* Service page */
  .service-page .sv-hero{padding:92px 0 48px}
  .service-page .sv-hero h1{font-size:clamp(1.6rem,6vw,2.2rem)}
  .sv-catch{font-size:.92rem}
  .sv-intro-sec,.sv-feat-sec,.sv-check-sec,.sv-price-sec,.sv-cases-sec,.sv-faq-sec{padding:48px 0}
  .sv-feat-grid{gap:16px;margin-top:32px}
  .sv-feat-card{padding:24px 20px}
  .sv-feat-num{font-size:1.8rem;margin-bottom:12px}
  .sv-feat-card h3{font-size:.98rem}
  .sv-feat-card p{font-size:.8rem;line-height:1.9}
  .sv-checklist{grid-template-columns:1fr;gap:8px;margin-top:24px}
  .sv-checklist li{padding:14px 18px;font-size:.85rem}
  .sv-price-grid{gap:14px;margin-top:32px}
  .sv-price-card{padding:24px 18px}
  .sv-price-card h3{font-size:.9rem;margin-bottom:12px}
  .sv-price-range{font-size:1.35rem}
  .sv-price-life{font-size:.68rem;margin-bottom:12px;padding-bottom:12px}
  .sv-price-desc{font-size:.74rem}
  .sv-price-note{margin-top:24px;font-size:.72rem}
  .sv-faq-list{margin-top:28px;gap:10px}
  .sv-faq-item{padding:18px 22px}
  .sv-faq-q{font-size:.85rem;gap:12px}
  .sv-faq-a{font-size:.78rem}
  /* Pager */
  .case-pager{margin-top:40px}
  .case-pager .page-numbers{padding:8px 12px;font-size:.78rem;margin:0 2px}
  /* Btn outline */
  .btn-outline{padding:12px 24px;font-size:.8rem}
}

/* ===== ULTRA-NARROW (subpage) ===== */
@media(max-width:380px){
  .sp-inner{padding:0 14px}
  .cc-body{padding:16px 18px}
  .voice-card,.cs-comment,.cs-voice{padding:20px 16px}
  .sv-feat-card,.sv-price-card{padding:20px 16px}
}
