/* ========================================
   result.css — 施工事例個別ページ
   ======================================== */

:root {
  --r-blue: #1e40af;
  --r-blue-light: #dbeafe;
  --r-blue-dark: #1e3a8a;
  --r-green: #059669;
  --r-text: #1f2937;
  --r-muted: #6b7280;
  --r-border: #e5e7eb;
  --r-bg: #f9fafb;
  --r-radius: 10px;
  --r-wrap: 900px;
}

main { background: var(--r-bg); }

/* ========== ヒーロー ========== */
.r-hero { background: #fff; padding: 40px 20px 32px; }
.r-hero-inner { max-width: var(--r-wrap); margin: 0 auto; }
.r-hero-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; margin-bottom: 20px; }
.r-hero-tag { font-size: 12px; padding: 3px 10px; border-radius: 14px; background: var(--r-blue-light); color: var(--r-blue); font-weight: 600; }
.r-hero-tag-plain { background: #f3f4f6; color: #374151; }
.r-hero h1 { font-size: clamp(16px, 4.5vw, 24px); font-weight: 700; color: var(--r-text); line-height: 1.4; margin: 0 0 12px; }
.r-hero-meta { display: flex; gap: 16px; font-size: 13px; color: var(--r-muted); margin-bottom: 24px; }

/* Before/After */
.r-ba { display: grid; grid-template-columns: 1fr 40px 1fr; gap: 10px; align-items: center; margin-bottom: 20px; }
.r-ba-label { font-size: 13px; font-weight: 700; text-align: center; padding: 4px; border-radius: 4px; margin-bottom: 6px; }
.r-ba-label.before { background: #fef2f2; color: #dc2626; }
.r-ba-label.after { background: #f0fdf4; color: #059669; }
.r-ba-img { border-radius: 8px; overflow: hidden; border: 1px solid var(--r-border); }
.r-ba-img img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.r-ba-arrow { text-align: center; font-size: 24px; color: #9ca3af; }

@media (max-width: 640px) {
  .r-ba { grid-template-columns: 1fr; }
  .r-ba-arrow { transform: rotate(90deg); }
}

/* 案件概要 */
.r-summary { font-size: 15px; color: #374151; line-height: 1.9; margin: 0 0 16px; }
.r-summary-list { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 6px; }
.r-summary-list li { font-size: 14px; color: #374151; padding: 8px 12px; background: var(--r-bg); border-left: 3px solid var(--r-blue); border-radius: 0 6px 6px 0; }
.r-links { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 20px; }
.r-links a { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; padding: 9px 16px; border-radius: 6px; text-decoration: none; transition: background .2s, transform .15s; background: #fff; color: var(--r-blue); border: 1.5px solid var(--r-blue); }
.r-links a:hover { background: var(--r-blue-light); transform: translateY(-1px); }
.r-links a.r-links-expertise { background: #0b1d33; color: #f39c12; border-color: #0b1d33; }
.r-links a.r-links-expertise:hover { background: #152b47; }

/* ========== 目次 ========== */
.r-toc { background: #fff; border: 1px solid var(--r-border); border-radius: var(--r-radius); padding: 20px 24px; max-width: var(--r-wrap); margin: 0 auto 0; }
.r-toc h2 { font-size: 14px; font-weight: 700; color: var(--r-text); margin: 0 0 10px; }
.r-toc ol { padding-left: 20px; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.r-toc li a { font-size: 14px; color: var(--r-blue); }

/* ========== セクション共通 ========== */
.r-section { padding: 56px 20px; }
.r-section-inner { max-width: var(--r-wrap); margin: 0 auto; }
.r-section-title { font-size: 22px; font-weight: 700; color: var(--r-text); margin: 0 0 28px; padding-bottom: 10px; border-bottom: 2px solid var(--r-blue); }

/* ========== 作業工程 ========== */
.r-steps { display: flex; flex-direction: column; gap: 16px; }
.r-step { display: grid; grid-template-columns: 100px 1fr; gap: 16px; background: #fff; border-radius: var(--r-radius); padding: 16px; }
.r-step-img img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 6px; display: block; }
.r-step-badge { display: inline-block; font-size: 11px; font-weight: 700; color: var(--r-blue); background: var(--r-blue-light); padding: 2px 8px; border-radius: 4px; margin-bottom: 6px; }
.r-step h3 { font-size: 15px; font-weight: 700; color: var(--r-text); margin: 0 0 6px; }
.r-step p { font-size: 13px; color: #374151; line-height: 1.7; margin: 0; }

@media (max-width: 600px) {
  .r-step { grid-template-columns: 1fr; }
  .r-step-img { display: none; }
}

/* ========== ギャラリー ========== */
.r-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.r-gallery-item { border-radius: 8px; overflow: hidden; background: #fff; border: 1px solid var(--r-border); }
.r-gallery-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.r-gallery-caption { padding: 8px 10px; }
.r-gallery-step { font-size: 10px; font-weight: 700; color: var(--r-blue); display: block; margin-bottom: 2px; }
.r-gallery-title { font-size: 12px; font-weight: 700; color: var(--r-text); display: block; margin-bottom: 3px; }
.r-gallery-desc { font-size: 11px; color: var(--r-muted); line-height: 1.5; margin: 0; }

@media (max-width: 640px) { .r-gallery { grid-template-columns: 1fr 1fr; } }
@media (max-width: 400px) { .r-gallery { grid-template-columns: 1fr; } }

/* ========== 関連事例 ========== */
.r-related { background: var(--r-bg); }
.r-related-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.r-related-card { background: #fff; border: 1px solid var(--r-border); border-radius: var(--r-radius); overflow: hidden; }
.r-related-card a { display: block; text-decoration: none; color: inherit; }
.r-related-card img { width: 100%; height: 140px; object-fit: cover; display: block; }
.r-related-card-body { padding: 12px; }
.r-related-card h3 { font-size: 14px; font-weight: 700; color: var(--r-text); line-height: 1.5; margin: 0 0 6px; }
.r-related-card p { font-size: 12px; color: var(--r-muted); line-height: 1.6; margin: 0; }
.r-area-banner { background: #fff; border: 1px solid var(--r-border); border-radius: var(--r-radius); overflow: hidden; }
.r-area-banner a { display: grid; grid-template-columns: 140px 1fr; text-decoration: none; color: inherit; }
.r-area-banner img { width: 100%; height: 100%; object-fit: cover; display: block; }
.r-area-banner-body { padding: 16px; }
.r-area-banner-label { font-size: 11px; font-weight: 700; color: var(--r-blue); display: block; margin-bottom: 4px; }
.r-area-banner-title { font-size: 15px; font-weight: 700; color: var(--r-text); margin: 0 0 6px; }
.r-area-banner-desc { font-size: 13px; color: var(--r-muted); line-height: 1.6; margin: 0 0 8px; }
.r-area-banner-cta { font-size: 13px; color: var(--r-blue); font-weight: 600; }

@media (max-width: 640px) {
  .r-related-cards { grid-template-columns: 1fr; }
  .r-area-banner a { grid-template-columns: 1fr; }
  .r-area-banner img { height: 160px; }
}

/* ========== FAQ ========== */
.r-faq { background: #374151; padding: 56px 20px; }
.r-faq-inner { max-width: var(--r-wrap); margin: 0 auto; }
.r-faq-title { font-size: 22px; font-weight: 700; color: #fff; margin: 0 0 28px; }
.r-faq-list { display: flex; flex-direction: column; gap: 12px; }
.r-faq-item { background: #fff; border-radius: var(--r-radius); padding: 20px; }
.r-faq-q { font-size: 15px; font-weight: 700; color: var(--r-text); margin: 0 0 10px; }
.r-faq-a { font-size: 14px; color: #374151; line-height: 1.8; margin: 0; }

/* ========== エリア ========== */
.r-area { background: #fff; padding: 48px 20px; }
.r-area-inner { max-width: var(--r-wrap); margin: 0 auto; }
.r-area-title { font-size: 20px; font-weight: 700; color: var(--r-text); margin: 0 0 16px; }
.r-area p { font-size: 14px; color: #374151; line-height: 1.9; margin: 0 0 10px; }
.r-area a { color: var(--r-blue); }

/* ========== CTA ========== */
.r-cta { background: #f3f4f6; padding: 56px 20px; text-align: center; }
.r-cta h2 { font-size: 24px; font-weight: 700; color: #1f2937; margin: 0 0 12px; }
.r-cta p { font-size: 14px; color: #374151; line-height: 1.8; margin: 0 0 28px; }
.r-cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 12px; }
.r-cta-btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px; border-radius: 50px; text-decoration: none; font-weight: 700; font-size: 16px; }
.r-cta-btn-tel { background: #fff; color: var(--r-blue); }
.r-cta-btn-line { background: #06C755; color: #fff; }
.r-cta-btn-sub { background: transparent; color: #374151; border: 2px solid #d1d5db; font-size: 14px; padding: 12px 24px; }
.r-cta-note { font-size: 13px; color: #6b7280; margin: 0 0 16px; }
.r-cta-links { display: none; }

@media (max-width: 640px) {
  .r-cta { padding: 40px 16px; }
  .r-cta h2 { font-size: 20px; }
  .r-cta-btns { flex-direction: column; align-items: stretch; }
  .r-cta-btn { justify-content: center; }
}

.r-section-toc { padding-top: 24px; padding-bottom: 24px; background: #fff; }
.r-section-white { background: #fff; }

/* ========== 一覧ページ Before/After カード ========== */
.r-ba-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: #1f2937; }
.r-ba-item { position: relative; aspect-ratio: 1/1; overflow: hidden; }
.r-ba-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.r-card:hover .r-ba-item img { transform: scale(1.04); }
.r-ba-lbl { position: absolute; top: 8px; left: 8px; font-size: 10px; font-weight: 700; letter-spacing: 1px; padding: 3px 8px; border-radius: 4px; }
.r-ba-lbl--before { background: #374151; color: #fff; }
.r-ba-lbl--after { background: #2a6e3f; color: #fff; }

/* ========== Before/After事例カード（case-card）========== */
.cases-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.case-card { background: #fff; border-radius: 16px; overflow: hidden; border: 1px solid var(--r-border); }
.case-ba { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: #1f2937; }
.case-ba-item { position: relative; aspect-ratio: 1/1; overflow: hidden; }
.case-ba-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.case-ba-label { position: absolute; top: 8px; left: 8px; font-size: 10px; font-weight: 700; letter-spacing: 1px; padding: 3px 8px; border-radius: 4px; }
.case-ba-label.before { background: #374151; color: #fff; }
.case-ba-label.after { background: #2a6e3f; color: #fff; }
.case-body { padding: 20px; }
.case-tag { display: inline-block; font-size: 11px; font-weight: 700; color: #1a5276; background: #e8f4f8; padding: 3px 10px; border-radius: 20px; margin-bottom: 10px; }
.case-title { font-size: 15px; font-weight: 700; color: var(--r-text); margin: 0 0 8px; line-height: 1.5; }
.case-desc { font-size: 12px; color: var(--r-muted); line-height: 1.7; margin: 0 0 14px; }
.case-link { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 700; color: #1a5276; text-decoration: none; }

@media (max-width: 640px) {
  .cases-grid { grid-template-columns: 1fr; }
}

/* ========== /result/ 一覧ページ専用 ========== */
/* ヒーロー */
.hero{background:var(--navy);padding:110px 20px 80px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-120px;right:-120px;width:480px;height:480px;border-radius:50%;border:60px solid rgba(243,156,18,.08);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-80px;left:-80px;width:300px;height:300px;border-radius:50%;border:40px solid rgba(26,82,118,.18);pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:750px;margin:0 auto}
.hero-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:4px;text-transform:uppercase;margin-bottom:20px;font-family:"Good Times"}
.hero-title{font-size:clamp(22px,4vw,36px);font-weight:900;color:#fff;line-height:1.4;margin:0 0 16px}
.hero-sub{font-size:15px;color:rgba(255,255,255,.8);line-height:2;margin:0}
@media(max-width:768px){.hero{padding:80px 20px 55px}.hero-sub{text-align:left;font-size:14px}}

/* セクション */
.result-wrap{max-width:980px;margin:0 auto;padding:60px 20px 100px}
.r-label{font-size:11px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase;margin-bottom:8px;font-family:"Good Times"}
.r-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.4}
.r-divider{width:40px;height:4px;background:var(--primary);border-radius:2px;margin:0 0 28px}
@media(max-width:768px){.result-wrap{padding:40px 12px 70px;width:100%;box-sizing:border-box;margin:0}}

/* フィルター */
.r-filter{background:var(--gray);border:1px solid var(--border);border-radius:10px;padding:20px 24px;margin-bottom:16px}
.r-filter-form{display:flex;flex-wrap:wrap;gap:16px 28px;align-items:flex-start}
.r-filter fieldset{border:0;padding:0;margin:0}
.r-filter legend{font-weight:700;font-size:13px;margin-bottom:8px;color:var(--primary)}
.r-checks{display:flex;flex-wrap:wrap;gap:8px}
.r-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:6px 12px;background:#fff;cursor:pointer;font-size:13px;line-height:1.2;transition:border-color .2s,background .2s}
.r-chip:has(input:checked){border-color:var(--primary);background:#eef4fb}
.r-chip input{accent-color:var(--primary);cursor:pointer}
.r-cnt{font-size:11px;color:var(--muted);background:#e8edf3;border-radius:999px;padding:2px 6px;min-width:20px;text-align:center}
.r-reset{border:0;background:#e2e8f0;border-radius:999px;padding:8px 16px;cursor:pointer;font-size:13px;font-family:"Noto Sans JP",sans-serif;transition:background .2s;align-self:flex-end}
.r-reset:hover{background:#cbd5e1}
.r-summary{font-size:13px;color:var(--muted);margin-bottom:8px;min-height:18px}
.r-hubs{margin-bottom:20px;font-size:13px}
.r-hubs .hub-label{color:var(--muted);margin-right:6px}
.r-hubs a{display:inline-block;margin:4px 4px 0 0;padding:5px 12px;border-radius:999px;background:var(--primary);color:#fff;text-decoration:none;font-size:12px;font-weight:700;transition:background .2s}
.r-hubs a:hover{background:#154360}

/* カードグリッド */
.r-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:20px 0;width:100%;align-items:start;box-sizing:border-box;padding:0;list-style:none}
.r-card{background:#fff;border-radius:10px;border:1px solid var(--border);overflow:hidden !important;transition:box-shadow .25s,transform .25s;min-width:0;display:flex;flex-direction:column;width:100%;box-sizing:border-box}
.r-card:hover{box-shadow:0 6px 24px rgba(11,29,51,.10);transform:translateY(-3px)}
.r-card a{display:flex;flex-direction:column;text-decoration:none;color:inherit;height:100%}
.r-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#eee}
.r-thumb img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.r-card:hover .r-thumb img{transform:scale(1.04)}
.r-meta{display:flex;flex-wrap:wrap;gap:4px 6px;padding:10px 12px 6px;align-items:center}
.r-day{font-size:11px;color:var(--muted);width:100%;margin-bottom:2px;font-family:"Good Times",sans-serif}
.r-tag{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:700;line-height:1.5}
.tag-a{background:#eef4fb;color:var(--primary);border:1px solid #bdd4ed}
.tag-t{background:#fef3e2;color:#92400e;border:1px solid #fcd28a}
.tag-b{background:#f0fdf4;color:#166534;border:1px solid #86efac}
.rc-title{
  padding:6px 12px 14px;
  font-size:13px;
  font-weight:700;
  color:#1f2937;
  line-height:1.65;
  word-break:break-all;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
@media(max-width:600px){
  .rc-title{
    font-size:12px;
    -webkit-line-clamp:3;
    padding:4px 10px 14px;
  }
}
.r-card.hidden{display:none}
@media(max-width:600px){.r-grid{grid-template-columns:1fr;gap:14px;margin:16px 0;width:100%;padding:0}.r-card{width:100%;margin:0}}

/* ページネーション */
.r-pager-wrap{display:flex;justify-content:center;margin:16px 0 24px}
.r-pager{display:flex;gap:6px;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.r-pager button{border:1px solid var(--border);background:#fff;border-radius:6px;padding:7px 13px;cursor:pointer;font-size:13px;font-family:"Noto Sans JP",sans-serif;transition:background .2s}
.r-pager button[aria-current="page"]{background:var(--primary);color:#fff;border-color:var(--primary)}
.r-pager button:hover:not([aria-current="page"]):not([disabled]){background:var(--gray)}
.r-pager button[disabled]{opacity:.4;cursor:not-allowed}

/* サービスリンク */
.r-service-links{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.r-service-card{display:flex;align-items:center;gap:14px;padding:20px 18px;background:linear-gradient(135deg,#0b1d33 0%,#1a5276 100%);border-radius:10px;text-decoration:none;color:#fff;transition:box-shadow .25s,transform .25s}
.r-service-card:hover{box-shadow:0 6px 24px rgba(11,29,51,.3);transform:translateY(-2px)}
.r-service-icon{flex-shrink:0;width:44px;height:44px;border:2px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}
.r-service-body{flex:1;min-width:0}
.r-service-label{display:inline-block;font-size:10px;letter-spacing:.1em;background:rgba(255,255,255,.15);border-radius:999px;padding:2px 8px;margin-bottom:5px}
.r-service-title{font-size:15px;font-weight:700;line-height:1.4;margin:0 0 3px}
.r-service-desc{font-size:11px;opacity:.8;line-height:1.5;margin:0}
.r-service-arrow{flex-shrink:0;font-size:16px;opacity:.6;transition:transform .3s}
.r-service-card:hover .r-service-arrow{transform:translateX(4px);opacity:1}
@media(max-width:768px){.r-service-links{grid-template-columns:1fr;gap:12px}.r-service-arrow{display:none}}
