/* ============================================================
   AIWA CREATE — 地域のビジネスに、確かなウェブの形を。
============================================================ */

:root {
  --c-bg: #ffffff;
  --c-soft: #f5f7fa;
  --c-dark: #0f1e3a;
  --c-dark-2: #07132a;
  --c-primary: #1a3b5c;
  --c-accent: #e8a846;
  --c-accent-2: #d4862e;
  --c-text: #1f2937;
  --c-text-2: #4b5563;
  --c-muted: #6b7280;
  --c-line: #e5e7eb;
  --c-line-2: #d1d5db;
  --c-success: #10b981;
  --shadow-sm: 0 1px 3px rgba(15, 30, 58, 0.06);
  --shadow-md: 0 8px 24px rgba(15, 30, 58, 0.08);
  --shadow-lg: 0 20px 50px rgba(15, 30, 58, 0.12);
  --radius: 8px;
  --radius-lg: 14px;
  --f-sans: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, sans-serif;
  --f-en: 'DM Sans', 'Noto Sans JP', sans-serif;
  --tr: 0.3s cubic-bezier(.4,0,.2,1);
  --container: 1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:80px;}
body{
  font-family: var(--f-sans);
  color: var(--c-text);
  background: var(--c-bg);
  line-height: 1.75;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "palt";
}
a{color:inherit;text-decoration:none;transition: color var(--tr), opacity var(--tr);}
ul,ol{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,textarea,select{font-family:inherit;font-size:15px;}
img{max-width:100%;display:block;}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;}
.container.narrow{max-width:860px;}
.hl{color:var(--c-accent);position:relative;font-weight:700;white-space:nowrap;}
.section{padding:120px 0;}
.section.soft{background:var(--c-soft);}
.section.dark{background:var(--c-dark);color:#e5e7eb;}
.section-head{margin-bottom:64px;max-width:780px;}
.section-label{
  display:inline-block;font-family:var(--f-en);
  font-size:12px;letter-spacing:0.3em;
  color:var(--c-accent-2);font-weight:600;
  padding-bottom:8px;margin-bottom:12px;
  border-bottom: 2px solid var(--c-accent);
}
.section-label.light{color:var(--c-accent);}
.section-title{
  font-size:clamp(28px,4vw,42px);font-weight:800;
  color:var(--c-primary);line-height:1.4;letter-spacing:0.02em;
}
.section-title.light{color:#fff;}
.section-desc{margin-top:16px;color:var(--c-text-2);font-size:15px;}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 24px;border-radius:var(--radius);font-weight:700;font-size:14px;
  letter-spacing:0.05em;transition: all var(--tr);
  white-space:nowrap;
}
.btn-lg{padding:18px 40px;font-size:16px;}
.btn-primary{background:var(--c-accent);color:#fff;box-shadow: 0 4px 14px rgba(232,168,70,0.3);}
.btn-primary:hover{background:var(--c-accent-2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,168,70,0.4);}
.btn-solid{background:var(--c-primary);color:#fff;}
.btn-solid:hover{background:var(--c-dark);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-line-2);}
.btn-ghost:hover{border-color:var(--c-primary);background:var(--c-primary);color:#fff;}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.3);}
.btn-ghost-light:hover{background:rgba(255,255,255,0.1);border-color:#fff;}
.btn-line{background:#06C755;color:#fff;box-shadow:0 4px 14px rgba(6,199,85,0.3);gap:8px;}
.btn-line:hover{background:#05b34c;transform:translateY(-2px);box-shadow:0 8px 24px rgba(6,199,85,0.4);}
.btn-ico{width:20px;height:20px;flex-shrink:0;}

/* ===== Header ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,0.94);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color var(--tr),box-shadow var(--tr);
}
.header.scrolled{border-bottom-color:var(--c-line);box-shadow:var(--shadow-sm);}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-logo{display:block;width:200px;height:auto;flex-shrink:0;}
.brand-mark{
  width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  color:var(--c-accent);display:grid;place-items:center;
  font-family:var(--f-en);font-weight:700;font-size:16px;
  letter-spacing:0.05em;
}
.brand-text{display:flex;flex-direction:column;line-height:1.2;}
.brand-name{font-family:var(--f-en);font-size:18px;font-weight:700;color:var(--c-primary);letter-spacing:0.08em;}
.brand-sub{font-size:10px;color:var(--c-muted);margin-top:2px;letter-spacing:0.02em;}

.nav ul{display:flex;gap:18px;}
.nav a{font-size:12.5px;font-weight:500;color:var(--c-text);padding:8px 0;position:relative;white-space:nowrap;}
.nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--c-accent);transition:width var(--tr);}
.nav a:hover{color:var(--c-primary);}
.nav a:hover::after{width:100%;}

.head-cta{display:flex;align-items:center;gap:14px;}
.head-tel{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2;}
.head-tel small{font-size:9px;color:var(--c-muted);letter-spacing:0.15em;}
.head-tel strong{font-family:var(--f-en);font-size:20px;font-weight:700;color:var(--c-primary);letter-spacing:0.02em;}

.hamb{display:none;width:32px;height:32px;flex-direction:column;justify-content:center;gap:6px;}
.hamb span{display:block;width:100%;height:2px;background:var(--c-primary);transition:var(--tr);}
.hamb.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.hamb.open span:nth-child(2){opacity:0;}
.hamb.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

.mobile-menu{
  position:fixed;top:76px;left:0;right:0;bottom:0;
  background:#fff;z-index:99;padding:32px 24px;
  transform:translateX(100%);transition:var(--tr);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu ul{display:flex;flex-direction:column;gap:4px;}
.mobile-menu a{display:block;padding:18px 0;border-bottom:1px solid var(--c-line);font-size:16px;font-weight:500;}
.mm-cta{background:var(--c-accent)!important;color:#fff!important;text-align:center;margin-top:16px;border-radius:var(--radius);padding:16px!important;border:none!important;}

/* ===== Hero ===== */
.hero{
  position:relative;padding:140px 0 100px;
  overflow:hidden;background:var(--c-bg);
}
.hero::before{
  content:'';position:absolute;top:0;right:0;bottom:0;
  width:40%;
  background:linear-gradient(135deg,#f8f9fb 0%, #eef2f7 100%);
  clip-path: polygon(20% 0, 100% 0, 100% 100%, 0 100%);
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;}
.hero-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:30px;
  background:rgba(26,59,92,0.06);color:var(--c-primary);
  font-size:12px;font-weight:600;letter-spacing:0.1em;
  margin-bottom:28px;
}
.chip-dot{width:8px;height:8px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 0 4px rgba(232,168,70,0.2);}
.hero-title{
  font-size:clamp(32px,5.5vw,60px);font-weight:800;
  color:var(--c-primary);line-height:1.35;letter-spacing:0.02em;
  margin-bottom:28px;
}
.hero-hl{white-space:normal;}
.hero-lead{font-size:16px;line-height:2;color:var(--c-text-2);margin-bottom:36px;max-width:560px;}
.hero-lead strong{color:var(--c-primary);font-weight:700;border-bottom:2px solid var(--c-accent);padding-bottom:1px;}
.hero-ctas{display:flex;gap:16px;margin-bottom:48px;flex-wrap:wrap;}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-top:32px;border-top:1px solid var(--c-line);}
.hero-stats li{display:flex;flex-direction:column;gap:4px;}
.hero-stats strong{font-family:var(--f-en);font-size:26px;font-weight:700;color:var(--c-primary);letter-spacing:0.02em;}
.hero-stats small{font-size:14px;color:var(--c-accent-2);margin-left:2px;}
.hero-stats span{font-size:11px;color:var(--c-muted);line-height:1.6;}

/* Hero right visual */
.hero-right{position:relative;}
.hero-photo{
  position:relative;border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-photo img{
  display:block;width:100%;height:100%;
  object-fit:cover;object-position:top center;
  border-radius:20px;
  min-height:400px;max-height:520px;
}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  border-radius:20px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0.06);
  pointer-events:none;
}
.hero-photo-card{
  position:absolute;bottom:24px;left:-20px;z-index:3;
  padding:16px 22px;background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,0.6);
}
.hpc-label{
  display:block;font-family:var(--f-en);font-size:10px;
  font-weight:700;letter-spacing:0.2em;color:var(--c-accent-2);
  margin-bottom:6px;
}
.hero-photo-card strong{
  font-size:14px;font-weight:700;color:var(--c-primary);line-height:1.55;
}

.hero-scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--f-en);font-size:10px;letter-spacing:0.3em;color:var(--c-muted);
}
.hero-scroll span{width:1px;height:40px;background:var(--c-line-2);position:relative;overflow:hidden;}
.hero-scroll span::after{content:'';position:absolute;top:0;left:0;right:0;height:40%;background:var(--c-accent);animation:scrollLine 2s ease-in-out infinite;}
@keyframes scrollLine{0%{transform:translateY(-100%);}100%{transform:translateY(250%);}}

/* ===== Story ===== */
.story-photo{
  margin-bottom:48px;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-md);
}
.story-photo img{
  display:block;width:100%;height:auto;
  object-fit:cover;aspect-ratio:16/7;
  border-radius:var(--radius-lg);
}
.story-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:start;}
.story-lead{
  font-size:22px;font-weight:600;line-height:1.8;color:var(--c-primary);
  padding:24px 0 24px 28px;border-left:3px solid var(--c-accent);
  margin-bottom:32px;
}
.story-text p{margin-bottom:18px;color:var(--c-text-2);line-height:2;}
.story-text strong{color:var(--c-primary);font-weight:700;}
.story-stats{display:flex;flex-direction:column;gap:16px;}
.sstat{
  background:var(--c-soft);padding:28px;border-radius:var(--radius-lg);
  display:flex;flex-direction:column;gap:6px;
  border-left:3px solid var(--c-primary);
}
.sstat.highlight{
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  border-left-color:var(--c-accent);color:#fff;
}
.sstat-n{font-family:var(--f-en);font-size:32px;font-weight:700;color:var(--c-primary);letter-spacing:0.02em;}
.sstat-n small{font-size:16px;color:var(--c-accent-2);}
.sstat.highlight .sstat-n{color:#fff;}
.sstat.highlight .sstat-n small{color:var(--c-accent);}
.sstat-l{font-size:12px;color:var(--c-muted);line-height:1.6;}
.sstat.highlight .sstat-l{color:rgba(255,255,255,0.85);}

/* ===== Local Needs ===== */
.local-needs{position:relative;}
.local-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.local-card{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:28px 24px;
  box-shadow:var(--shadow-sm);transition:all var(--tr);
}
.local-card:hover{
  border-color:var(--c-accent);box-shadow:var(--shadow-md);
  transform:translateY(-3px);
}
.local-keyword{
  display:inline-flex;align-items:center;
  min-height:28px;padding:5px 11px;margin-bottom:16px;
  background:rgba(232,168,70,0.12);color:var(--c-accent-2);
  border-radius:999px;font-size:11px;font-weight:700;
  letter-spacing:0.04em;line-height:1.4;
}
.local-card h3{
  font-size:17px;line-height:1.55;color:var(--c-primary);
  margin-bottom:10px;font-weight:700;
}
.local-card p{
  font-size:13px;line-height:1.9;color:var(--c-text-2);
}

/* ===== Services ===== */
.srv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.srv-card{
  padding:40px;background:rgba(255,255,255,0.04);
  border:1px solid rgba(232,168,70,0.2);border-radius:var(--radius-lg);
  transition: all var(--tr);
}
.srv-card:hover{background:rgba(255,255,255,0.08);border-color:var(--c-accent);transform:translateY(-4px);}
.srv-num{font-family:var(--f-en);font-size:28px;font-weight:700;color:var(--c-accent);letter-spacing:0.05em;margin-bottom:16px;}
.srv-card h3{font-size:22px;font-weight:700;color:#fff;margin-bottom:14px;}
.srv-card p{font-size:14px;line-height:1.9;color:#cbd5e1;margin-bottom:20px;}
.srv-tags{display:flex;flex-wrap:wrap;gap:8px;}
.srv-tags li{
  font-size:11px;padding:6px 12px;
  background:rgba(232,168,70,0.1);color:var(--c-accent);
  border-radius:30px;font-weight:500;letter-spacing:0.05em;
}
.srv-link{
  display:inline-flex;margin-top:22px;
  color:var(--c-accent);font-size:13px;font-weight:700;
}
.srv-link:hover{color:#fff;}

/* ===== Reasons ===== */
.rs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.rs{
  padding:36px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);transition: all var(--tr);
}
.rs:hover{border-color:var(--c-accent);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.rs-num{
  display:inline-block;font-family:var(--f-en);
  font-size:32px;font-weight:700;color:var(--c-accent);
  letter-spacing:0.02em;margin-bottom:12px;
}
.rs h3{font-size:18px;font-weight:700;color:var(--c-primary);margin-bottom:12px;line-height:1.5;}
.rs p{font-size:14px;line-height:1.9;color:var(--c-text-2);}
.rs strong{color:var(--c-primary);font-weight:700;}
.rs-feature{
  grid-column:span 3;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  border:none;padding:48px;display:flex;align-items:center;justify-content:center;
  gap:48px;
}
.rs-feature-photo{
  flex-shrink:0;width:220px;border-radius:var(--radius-lg);overflow:hidden;
}
.rs-feature-photo img{
  display:block;width:100%;height:auto;
  object-fit:cover;aspect-ratio:3/2;
  border-radius:var(--radius-lg);
  opacity:0.9;
}
.rs-feature-inner{max-width:600px;text-align:center;}
.rs-feature h3{font-size:28px;color:var(--c-accent);margin-bottom:16px;line-height:1.5;}
.rs-feature p{color:rgba(255,255,255,0.9);font-size:15px;}
.rs-feature strong{color:#fff;}

/* ===== Plans ===== */
.plan-category{
  font-size:22px;font-weight:700;color:var(--c-primary);
  margin:60px 0 32px;padding-bottom:12px;
  border-bottom:1px solid var(--c-line);
  display:flex;align-items:center;gap:12px;
}
.plan-category::before{
  content:'';width:4px;height:24px;background:var(--c-accent);border-radius:2px;
}
.plan-category:first-of-type{margin-top:0;}
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.plan-grid-3{grid-template-columns:repeat(3,1fr);}
.plan-grid-2{grid-template-columns:repeat(2,1fr);}
.plan{
  position:relative;background:#fff;padding:36px 28px;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  transition: all var(--tr);
}
.plan:hover{border-color:var(--c-accent);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.plan.featured{border:2px solid var(--c-accent);box-shadow:var(--shadow-md);}
.plan-tag{
  position:absolute;top:-12px;right:20px;
  padding:6px 14px;font-size:11px;font-weight:700;
  letter-spacing:0.1em;border-radius:20px;
}
.plan-tag.new{background:var(--c-success);color:#fff;}
.plan-tag.popular{background:var(--c-accent);color:#fff;}
.plan h4{font-size:20px;font-weight:700;color:var(--c-primary);margin-bottom:16px;}
.plan-price{font-family:var(--f-en);font-size:32px;font-weight:700;color:var(--c-primary);line-height:1;margin-bottom:12px;}
.plan-price span{font-size:20px;margin-right:2px;}
.plan-price small{font-size:14px;color:var(--c-muted);font-weight:500;margin-left:2px;}
.plan-for{font-size:12px;color:var(--c-muted);margin-bottom:20px;padding-bottom:16px;border-bottom:1px dashed var(--c-line);line-height:1.6;}
.plan-specs li{font-size:13px;padding:6px 0 6px 22px;position:relative;color:var(--c-text-2);}
.plan-specs li::before{content:'✓';position:absolute;left:0;top:6px;color:var(--c-accent);font-weight:700;}

/* ===== Tiered maintenance plan ===== */
.plan-tiered{
  margin-bottom:20px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);overflow:hidden;
}
.plan-tiered-head{
  padding:32px 36px;background:linear-gradient(135deg, var(--c-soft) 0%, #fff 100%);
  border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;
}
.ptd-range{display:flex;flex-direction:column;align-items:flex-start;gap:6px;}
.ptd-label{
  font-size:11px;font-weight:700;color:var(--c-muted);
  letter-spacing:0.15em;text-transform:uppercase;
}
.ptd-amount{
  font-family:var(--f-en);font-weight:800;color:var(--c-primary);
  font-size:34px;line-height:1;letter-spacing:0.01em;
}
.ptd-amount span{font-size:20px;margin-right:2px;}
.ptd-amount em{font-style:normal;font-size:20px;color:var(--c-muted);margin:0 6px;font-weight:600;}
.ptd-amount small{font-size:13px;color:var(--c-muted);font-weight:500;margin-left:6px;}
.ptd-lead{font-size:14px;line-height:1.9;color:var(--c-text-2);margin:0;}
.ptd-lead strong{color:var(--c-primary);font-weight:700;}

.plan-tiered-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
}
.ptd-plan{
  border:none;border-radius:0;padding:32px 36px;
  border-right:1px solid var(--c-line);
}
.ptd-plan:last-child{border-right:none;}
.ptd-plan:hover{transform:none;border-color:transparent;box-shadow:none;background:rgba(232,168,70,0.03);}
.ptd-featured{background:rgba(232,168,70,0.04);}
.ptd-tag{
  display:inline-block;padding:5px 12px;
  font-size:11px;font-weight:700;letter-spacing:0.08em;
  background:var(--c-soft);color:var(--c-text-2);border-radius:20px;
  margin-bottom:14px;
}
.ptd-tag-on{background:var(--c-accent);color:#fff;}

@media (max-width:700px){
  .plan-tiered-head{grid-template-columns:1fr;gap:14px;padding:24px;}
  .ptd-amount{font-size:28px;}
  .plan-tiered-grid{grid-template-columns:1fr;}
  .ptd-plan{border-right:none;border-bottom:1px solid var(--c-line);padding:26px 24px;}
  .ptd-plan:last-child{border-bottom:none;}
}

.plan-common{
  margin:40px 0 0;padding:36px 40px;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
}
.plan-common h4{
  font-size:15px;color:var(--c-primary);font-weight:700;
  margin-bottom:24px;padding-bottom:14px;
  border-bottom:1px solid var(--c-line);
  letter-spacing:0.08em;
  display:flex;align-items:center;gap:10px;
}
.plan-common h4::before{
  content:'';width:4px;height:16px;
  background:var(--c-accent);border-radius:2px;
}
.plan-common ul{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:18px 40px;
}
.plan-common li{
  padding:6px 0 6px 26px;position:relative;
  display:flex;flex-direction:column;gap:4px;
  color:var(--c-text-2);font-size:13px;
}
.plan-common li::before{
  content:'';position:absolute;left:4px;top:14px;
  width:8px;height:8px;border-radius:50%;
  background:var(--c-accent);
}
.plan-common li strong{
  font-size:14px;font-weight:700;color:var(--c-primary);
  line-height:1.55;letter-spacing:0.02em;
}
.plan-common li span{
  font-size:12px;color:var(--c-muted);line-height:1.75;
}
.plan-common-sub{
  margin-top:28px;padding-top:20px;
  border-top:1px dashed var(--c-line);
  font-size:13px;color:var(--c-text-2);line-height:1.95;
}
.plan-common-sub strong{color:var(--c-primary);font-weight:700;}

.plan-note{margin-top:40px;padding:20px;background:#fff;border-left:3px solid var(--c-accent);font-size:13px;color:var(--c-text-2);line-height:1.9;}
.plan-note strong{color:var(--c-primary);}

/* ===== Plan Intro (2-plan comparison) ===== */
.plan-intro{
  max-width:820px;margin-bottom:40px;
  padding:28px 32px;background:#fff;
  border-left:4px solid var(--c-accent);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  box-shadow:var(--shadow-sm);
}
.plan-intro-lead{
  font-size:17px;line-height:1.9;font-weight:500;
  color:var(--c-primary);margin-bottom:14px;
}
.plan-intro-lead strong{color:var(--c-accent-2);font-weight:700;}
.plan-intro-sub{
  font-size:14px;line-height:1.9;color:var(--c-text-2);
}
.plan-intro-sub em{
  font-style:normal;color:var(--c-primary);font-weight:700;
  background: linear-gradient(transparent 60%, rgba(232,168,70,0.25) 60%);
  padding:0 2px;
}

/* ===== Plan Compare (2 cards) ===== */
.plan-compare{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
  margin-bottom:40px;
}

/* ===== Single plan (おまかせ更新プラン) ===== */
.plan-solo{
  position:relative;background:#fff;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  margin-bottom:32px;overflow:hidden;
}
.plan-solo::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg, var(--c-primary), var(--c-accent));
  opacity:0.95;z-index:1;
}
.plan-solo-head{
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;
  padding:48px 48px 40px;
  border-bottom:1px solid var(--c-line);
}
.plan-solo-head-right{
  padding-left:40px;border-left:1px solid var(--c-line);
  display:flex;flex-direction:column;
}
.plan-solo-badge{
  display:inline-block;align-self:flex-start;
  font-size:11px;font-weight:700;letter-spacing:0.08em;
  padding:6px 14px;border-radius:20px;
  background:rgba(26,59,92,0.08);color:var(--c-primary);
  margin-bottom:18px;
}
.plan-solo-title{
  font-size:30px;font-weight:800;color:var(--c-primary);
  margin-bottom:10px;letter-spacing:0.02em;line-height:1.3;
}
.plan-solo-tagline{
  font-size:15px;color:var(--c-accent-2);font-weight:600;
  margin-bottom:24px;line-height:1.7;
}
.plan-solo-points{
  display:flex;flex-direction:column;gap:8px;
  padding-top:20px;border-top:1px dashed var(--c-line);
}
.plan-solo-points li{
  position:relative;padding-left:22px;
  font-size:13.5px;line-height:1.75;color:var(--c-text-2);
}
.plan-solo-points li::before{
  content:'';position:absolute;left:6px;top:10px;
  width:6px;height:6px;border-radius:50%;background:var(--c-accent);
}
.plan-solo-price-label{
  font-size:11px;font-weight:700;letter-spacing:0.18em;
  color:var(--c-muted);text-transform:uppercase;margin-bottom:10px;
}
.plan-solo-price{
  display:flex;align-items:baseline;gap:6px;margin-bottom:8px;
}
.pss-amount{
  font-family:var(--f-en);font-size:54px;font-weight:800;
  color:var(--c-primary);line-height:1;letter-spacing:0.01em;
}
.pss-amount small{
  font-family:var(--f-sans);font-size:22px;font-weight:700;
  color:var(--c-primary);margin-left:6px;
}
.pss-unit{
  font-family:var(--f-en);font-size:22px;
  color:var(--c-muted);font-weight:500;
}
.plan-solo-price-note{
  font-size:11.5px;color:var(--c-muted);line-height:1.7;
  margin-bottom:20px;padding-bottom:18px;
  border-bottom:1px dashed var(--c-line);
}
.plan-solo-features{
  display:flex;flex-direction:column;gap:8px;
}
.plan-solo-features li{
  position:relative;padding-left:22px;
  font-size:13px;line-height:1.7;color:var(--c-text-2);
}
.plan-solo-features li::before{
  content:'✓';position:absolute;left:0;top:0;
  color:var(--c-success);font-weight:700;
}
.plan-solo-scope{
  padding:28px 48px;background:rgba(15,30,58,0.03);
  border-bottom:1px solid var(--c-line);
}
.plan-solo-scope h5{
  font-size:13px;font-weight:700;color:var(--c-primary);
  letter-spacing:0.08em;margin-bottom:14px;
  padding-left:12px;position:relative;
}
.plan-solo-scope h5::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:4px;height:14px;background:var(--c-accent);border-radius:2px;
}
.plan-solo-scope-list{
  display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;
}
.plan-solo-scope-list li{
  position:relative;padding-left:16px;
  font-size:12.5px;line-height:1.75;color:var(--c-text-2);
}
.plan-solo-scope-list li::before{
  content:'—';position:absolute;left:0;top:0;
  color:var(--c-accent);font-weight:700;
}
.plan-solo-samples{padding:32px 48px;}

@media (max-width:900px){
  .plan-solo-head{grid-template-columns:1fr;gap:32px;padding:36px 32px 28px;}
  .plan-solo-head-right{padding-left:0;border-left:none;border-top:1px solid var(--c-line);padding-top:28px;}
  .plan-solo-scope-list{grid-template-columns:1fr;}
}
@media (max-width:700px){
  .plan-solo-head{padding:28px 22px 22px;gap:24px;}
  .plan-solo-title{font-size:24px;}
  .pss-amount{font-size:42px;}
  .pss-amount small{font-size:18px;}
  .plan-solo-scope{padding:22px;}
  .plan-solo-samples{padding:24px 22px 28px;}
}
.plan-c{
  background:#fff;padding:40px;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  display:flex;flex-direction:column;
  transition: all var(--tr);position:relative;
}
.plan-c:hover{
  border-color:var(--c-accent);
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.plan-c::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg, var(--c-primary), var(--c-accent));
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  opacity:0.9;
}
.plan-c-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;gap:12px;flex-wrap:wrap;
}
.plan-c-label{
  font-family:var(--f-en);font-size:12px;font-weight:700;
  letter-spacing:0.25em;color:var(--c-accent-2);
  padding:4px 0;
}
.plan-c-badge{
  font-size:11px;font-weight:600;letter-spacing:0.05em;
  padding:5px 12px;border-radius:20px;
  background:rgba(26,59,92,0.08);color:var(--c-primary);
}
.plan-c-title{
  font-size:26px;font-weight:800;color:var(--c-primary);
  margin-bottom:8px;letter-spacing:0.02em;
}
.plan-c-tagline{
  font-size:14px;color:var(--c-accent-2);font-weight:600;
  margin-bottom:24px;
}
.plan-c-price{
  display:flex;align-items:baseline;gap:4px;
  padding:20px 0 12px;
  border-top:1px dashed var(--c-line);
}
.pc-amount{
  font-family:var(--f-en);font-size:42px;font-weight:700;
  color:var(--c-primary);line-height:1;letter-spacing:0.02em;
}
.pc-amount small{
  font-family:var(--f-sans);font-size:18px;font-weight:600;
  color:var(--c-primary);margin-left:4px;
}
.pc-unit{
  font-family:var(--f-en);font-size:20px;
  color:var(--c-muted);font-weight:500;
}
.plan-c-price-note{
  font-size:11px;color:var(--c-muted);
  margin-bottom:24px;padding-bottom:20px;
  border-bottom:1px dashed var(--c-line);
}
.plan-c-body{flex:1;display:flex;flex-direction:column;gap:22px;}
.plan-c-section h5{
  font-size:13px;font-weight:700;color:var(--c-primary);
  letter-spacing:0.08em;margin-bottom:12px;
  padding-left:12px;position:relative;
}
.plan-c-section h5::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:4px;height:14px;background:var(--c-accent);border-radius:2px;
}
.plan-c-points,.plan-c-features{
  display:flex;flex-direction:column;gap:8px;
}
.plan-c-points li,.plan-c-features li{
  position:relative;padding-left:24px;
  font-size:13.5px;line-height:1.75;color:var(--c-text-2);
}
.plan-c-points li::before{
  content:'';position:absolute;left:6px;top:10px;
  width:6px;height:6px;border-radius:50%;background:var(--c-accent);
}
.plan-c-features li::before{
  content:'✓';position:absolute;left:0;top:0;
  color:var(--c-success);font-weight:700;font-size:14px;
}

/* ===== Plan Scope (この価格帯で想定している内容) ===== */
.plan-c-scope{
  padding:18px 20px;
  background:rgba(15,30,58,0.04);
  border-radius:var(--radius);
}
.plan-c-scope h5{margin-bottom:12px;}
.plan-c-scope-list{display:flex;flex-direction:column;gap:6px;}
.plan-c-scope-list li{
  position:relative;padding-left:16px;
  font-size:12.5px;line-height:1.75;color:var(--c-text-2);
}
.plan-c-scope-list li::before{
  content:'—';position:absolute;left:0;top:0;
  color:var(--c-accent);font-weight:700;
}

/* ===== Price Factors (価格が変動する主な要因) ===== */
.price-factors{
  margin-top:32px;padding:36px 40px;
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
}
.pf-head-block{
  margin-bottom:24px;padding-bottom:18px;
  border-bottom:1px solid var(--c-line);
}
.price-factors h4{
  font-size:15px;color:var(--c-primary);font-weight:700;
  margin-bottom:12px;letter-spacing:0.08em;
  display:flex;align-items:center;gap:10px;
}
.price-factors h4::before{
  content:'';width:4px;height:16px;
  background:var(--c-accent);border-radius:2px;
}
.pf-lead{
  font-size:13px;color:var(--c-text-2);line-height:1.95;
}
.pf-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:18px 36px;
}
.pf-list li{
  display:flex;gap:14px;align-items:flex-start;
}
.pf-ico{
  flex-shrink:0;width:26px;height:26px;
  border-radius:50%;
  background:rgba(232,168,70,0.18);color:var(--c-accent-2);
  font-size:15px;font-weight:700;
  display:grid;place-items:center;
  line-height:1;
}
.pf-list li > div{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;}
.pf-list li strong{
  font-size:13.5px;font-weight:700;color:var(--c-primary);line-height:1.5;
}
.pf-list li span{
  font-size:12px;color:var(--c-muted);line-height:1.7;
}

/* ===== Plan Flex Note ===== */
.plan-flex-note{
  margin:24px 0 0;padding:24px 28px;
  background:#fff;border:1px solid var(--c-line);
  border-left:3px solid var(--c-accent);border-radius:var(--radius);
  font-size:13.5px;line-height:1.9;color:var(--c-text-2);
}
.plan-flex-note strong{
  color:var(--c-primary);font-weight:700;
  border-bottom:2px solid var(--c-accent);padding-bottom:1px;
}

/* ===== Works ===== */
.works-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.work{border-radius:var(--radius-lg);overflow:hidden;background:#fff;border:1px solid var(--c-line);transition: all var(--tr);}
.work:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.work-featured{
  grid-column:span 2;grid-row:span 2;
  display:flex;flex-direction:column;
  border:2px solid var(--c-accent);
}
.work-tag{
  display:inline-block;margin:20px 20px 0;
  padding:4px 12px;background:var(--c-accent);color:#fff;
  font-family:var(--f-en);font-size:11px;font-weight:700;letter-spacing:0.1em;
  border-radius:20px;align-self:flex-start;
}
.work-visual{
  flex:1;min-height:240px;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  display:grid;place-items:center;position:relative;overflow:hidden;margin:16px 20px 0;border-radius:var(--radius);
}
.work-visual::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 40%, rgba(232,168,70,0.2) 0%, transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(255,255,255,0.05) 0%, transparent 40%);
}
.visual-text{
  font-family:var(--f-en);font-size:48px;font-weight:700;
  color:var(--c-accent);line-height:1;letter-spacing:0.05em;
  text-align:center;position:relative;z-index:1;
}
.work-link-label{
  position:absolute;bottom:14px;right:16px;z-index:1;
  font-size:12px;font-weight:600;color:rgba(255,255,255,0.7);
  letter-spacing:0.05em;transition:all var(--tr);
}
.work-visual:hover .work-link-label{color:#fff;}
a.work-visual{cursor:pointer;}
a.work-visual:hover{opacity:0.9;transform:scale(1.02);transition:all var(--tr);}
.visual-kstyle{
  background:linear-gradient(135deg, #e89b2d, #c57a1a);
}
.visual-kstyle::before{
  background:
    radial-gradient(circle at 30% 40%, rgba(255,255,255,0.15) 0%, transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(0,0,0,0.1) 0%, transparent 40%);
}
.visual-kstyle .visual-text{
  color:#fff;font-size:42px;
}
.visual-kataduke009{
  background:linear-gradient(135deg, #2f6f3e, #123f2f);
}
.visual-kataduke009::before{
  background:
    radial-gradient(circle at 24% 36%, rgba(124,199,82,0.28) 0%, transparent 44%),
    radial-gradient(circle at 76% 72%, rgba(255,255,255,0.08) 0%, transparent 38%);
}
.visual-kataduke009 .visual-text{
  color:#f4fff3;font-size:38px;
}
.visual-kaitai{
  background:linear-gradient(135deg, #24384d, #0c1824);
}
.visual-kaitai::before{
  background:
    radial-gradient(circle at 30% 35%, rgba(232,168,70,0.28) 0%, transparent 46%),
    radial-gradient(circle at 78% 70%, rgba(255,255,255,0.07) 0%, transparent 40%);
}
.visual-kaitai .visual-text{
  color:var(--c-accent);font-size:38px;
}
.work-body{padding:24px 20px;}
.work-meta{font-size:11px;color:var(--c-accent-2);letter-spacing:0.15em;font-weight:600;display:block;margin-bottom:8px;}
.work-body h3{font-size:22px;color:var(--c-primary);margin-bottom:12px;font-weight:700;}
.work-body p{font-size:14px;line-height:1.9;color:var(--c-text-2);margin-bottom:16px;}
.work-body strong{color:var(--c-primary);}
.work-specs li{font-size:12px;color:var(--c-muted);padding:2px 0;}
.work-detail-link{
  display:inline-flex;margin-top:12px;
  color:var(--c-accent-2);font-size:13px;font-weight:700;
}
.work-detail-link:hover{color:var(--c-primary);}

.work-coming{
  min-height:200px;background:var(--c-soft);border:2px dashed var(--c-line-2);
  display:grid;place-items:center;text-align:center;padding:24px;
}
.coming-label{
  display:inline-block;padding:4px 12px;background:#fff;border:1px solid var(--c-line);
  font-size:10px;font-weight:700;letter-spacing:0.15em;
  color:var(--c-muted);border-radius:20px;margin-bottom:12px;
}
.work-coming h3{font-size:18px;color:var(--c-primary);margin-bottom:8px;}
.work-coming p{font-size:12px;color:var(--c-muted);line-height:1.6;}
.work-coming strong{color:var(--c-accent-2);}

.work-support{
  min-height:200px;background:#fff;
  border:1px solid var(--c-line);
  display:flex;align-items:center;
}
.work-support.accent{
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  border:none;color:#fff;
}
.work-support-inner{padding:28px;}
.work-support h3{
  font-size:18px;line-height:1.55;color:var(--c-primary);
  margin-bottom:10px;font-weight:700;
}
.work-support.accent h3{color:#fff;}
.work-support p{
  font-size:13px;line-height:1.9;color:var(--c-text-2);
}
.work-support.accent p{color:rgba(255,255,255,0.86);}
.work-support-link{
  display:inline-flex;margin-top:14px;
  color:var(--c-accent);font-size:13px;font-weight:700;
}
.work-support-link:hover{color:#fff;}

/* ===== Process ===== */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.steps li{padding:36px 28px;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);position:relative;}
.step-n{
  font-family:var(--f-en);font-size:28px;font-weight:700;
  color:var(--c-accent);margin-bottom:12px;letter-spacing:0.02em;
}
.steps h3{font-size:18px;color:var(--c-primary);margin-bottom:10px;}
.steps p{font-size:14px;line-height:1.9;color:var(--c-text-2);}

/* ===== FAQ ===== */
.faq-list{display:flex;flex-direction:column;gap:8px;}
.faq-i{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;transition: all var(--tr);}
.faq-i:hover{border-color:var(--c-accent);}
.faq-i dt{padding:22px 24px;font-weight:700;color:var(--c-primary);cursor:pointer;position:relative;padding-right:60px;font-size:15px;}
.faq-i dt::before{content:'Q';font-family:var(--f-en);color:var(--c-accent);margin-right:12px;font-size:16px;font-weight:800;}
.faq-i dt::after{content:'+';position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--c-accent);transition: transform var(--tr);}
.faq-i.open dt::after{transform:translateY(-50%) rotate(45deg);}
.faq-i dd{padding:0 24px;max-height:0;overflow:hidden;transition:all var(--tr);font-size:14px;line-height:1.9;color:var(--c-text-2);}
.faq-i.open dd{padding:0 24px 24px;max-height:500px;}
.faq-i dd::before{content:'A';font-family:var(--f-en);color:var(--c-accent);margin-right:12px;font-weight:800;}
.faq-i strong{color:var(--c-primary);}

/* ===== CTA section ===== */
.cta{
  background:linear-gradient(135deg, var(--c-primary) 0%, var(--c-dark) 100%);
  padding:80px 0;text-align:center;color:#fff;position:relative;overflow:hidden;
}
.cta::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(232,168,70,0.15) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(232,168,70,0.1) 0%, transparent 40%);
}
.cta-inner{position:relative;z-index:1;}
.cta-photo{
  width:100px;height:100px;margin:0 auto 24px;
  border-radius:50%;overflow:hidden;
  border:3px solid rgba(255,255,255,0.2);
  box-shadow:0 8px 24px rgba(0,0,0,0.15);
}
.cta-photo img{
  display:block;width:100%;height:100%;object-fit:cover;
  object-position:center 20%;
}
.cta h2{font-size:clamp(24px,3.5vw,38px);font-weight:800;margin-bottom:20px;color:#fff;}
.cta p{font-size:15px;line-height:2;color:rgba(255,255,255,0.9);margin-bottom:36px;}
.cta strong{color:var(--c-accent);font-weight:700;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;}
.contact-info{display:flex;flex-direction:column;gap:28px;}
.ci-block{padding:28px;background:var(--c-soft);border-radius:var(--radius-lg);border-left:3px solid var(--c-accent);}
.ci-block h3{font-size:13px;color:var(--c-muted);letter-spacing:0.15em;margin-bottom:8px;font-weight:600;}
.ci-tel{display:block;font-family:var(--f-en);font-size:28px;font-weight:700;color:var(--c-primary);margin-bottom:8px;letter-spacing:0.02em;}
.ci-mail{display:block;font-family:var(--f-en);font-size:18px;font-weight:500;color:var(--c-primary);margin-bottom:8px;word-break:break-all;}
.ci-block p{font-size:13px;color:var(--c-text-2);line-height:1.8;}

.contact-form{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);padding:40px;}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--c-primary);margin-bottom:20px;}
.contact-form label span{display:inline-block;font-size:10px;padding:2px 8px;background:var(--c-accent);color:#fff;margin-left:8px;border-radius:3px;font-weight:700;letter-spacing:0.05em;}
.contact-form input, .contact-form textarea, .contact-form select{padding:12px 14px;background:#fafafa;border:1px solid var(--c-line);border-radius:var(--radius);color:var(--c-text);font-weight:400;transition:all var(--tr);}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{outline:none;border-color:var(--c-accent);background:#fff;box-shadow:0 0 0 3px rgba(232,168,70,0.15);}
.fi-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.fi-row label{margin-bottom:0;}
.fi-honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.fi-submit{text-align:center;margin-top:24px;}
.fi-submit small{display:block;margin-top:12px;font-size:11px;color:var(--c-muted);}

/* LINE block in contact-info */
.ci-line{border-left-color:#06C755;}
.ci-line h3{color:#06C755;}
.ci-line-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:#06C755;color:#fff;
  padding:12px 18px;border-radius:var(--radius);
  font-weight:700;font-size:14px;letter-spacing:0.03em;
  margin-bottom:10px;transition:all var(--tr);
  box-shadow:0 4px 14px rgba(6,199,85,0.25);
}
.ci-line-btn:hover{background:#05b34c;transform:translateY(-2px);box-shadow:0 8px 24px rgba(6,199,85,0.35);}
.ci-line-ico{width:22px;height:22px;flex-shrink:0;}
.ci-line-arrow{margin-left:4px;}

/* Form: fieldset (radio group) */
.contact-form .fi-fieldset{
  border:none;padding:0;margin:0 0 20px;
}
.contact-form .fi-fieldset legend{
  display:block;font-size:13px;font-weight:600;color:var(--c-primary);margin-bottom:8px;padding:0;
}
.fi-radio-row{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;
}
.contact-form .fi-radio{
  display:inline-flex;align-items:center;gap:6px;flex-direction:row;
  margin:0;padding:8px 14px;
  background:#fafafa;border:1px solid var(--c-line);border-radius:999px;
  font-size:13px;font-weight:500;color:var(--c-text);cursor:pointer;
  transition:all var(--tr);
}
.contact-form .fi-radio input{appearance:none;width:14px;height:14px;border:1.5px solid var(--c-line-2);border-radius:50%;margin:0;padding:0;background:#fff;position:relative;cursor:pointer;}
.contact-form .fi-radio input:checked{border-color:var(--c-accent);background:var(--c-accent);box-shadow:inset 0 0 0 3px #fff;}
.contact-form .fi-radio:has(input:checked){background:rgba(232,168,70,0.08);border-color:var(--c-accent);color:var(--c-primary);}
.contact-form .fi-radio span{font-weight:600;margin-left:0;padding:0;background:none;color:inherit;font-size:inherit;border-radius:0;letter-spacing:0;}

/* Form: privacy checkbox */
.contact-form label.fi-check{
  display:flex;flex-direction:row;
  align-items:flex-start;gap:12px;
  padding:16px 18px;background:var(--c-soft);border-radius:var(--radius);
  margin-bottom:8px;
}
.contact-form label.fi-check input[type="checkbox"]{
  width:20px;height:20px;flex-shrink:0;margin-top:2px;padding:0;
  accent-color:var(--c-accent);cursor:pointer;background:#fff;border:1px solid var(--c-line);
}
.contact-form label.fi-check > span{
  font-size:13px;color:var(--c-text-2);line-height:1.7;font-weight:400;
  display:inline;padding:0;background:none;border-radius:0;letter-spacing:0;margin-left:0;
}
.contact-form label.fi-check > span strong{color:var(--c-primary);font-weight:700;}
.contact-form label.fi-check > span em{
  display:inline-block;font-style:normal;font-size:10px;padding:2px 8px;
  background:var(--c-accent);color:#fff;border-radius:3px;font-weight:700;letter-spacing:0.05em;margin-left:4px;
}
.contact-form label.fi-check > span small{display:block;margin-top:6px;font-size:11px;color:var(--c-muted);line-height:1.6;}

/* Footer LINE link */
.foot-line{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;padding:10px 16px;
  background:#06C755;color:#fff;
  border-radius:var(--radius);font-size:13px;font-weight:700;
  transition:all var(--tr);
}
.foot-line:hover{background:#05b34c;transform:translateY(-1px);}
.foot-line svg{width:18px;height:18px;}
.foot-line:hover{color:#fff;}

/* Floating Action Button (FAB) */
.fab{
  position:fixed;right:20px;bottom:20px;z-index:80;
  display:flex;flex-direction:column;gap:10px;
  opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity 0.3s, transform 0.3s;
}
.fab.is-visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.fab-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;
  color:#fff;text-decoration:none;
  box-shadow:0 6px 18px rgba(0,0,0,0.18);
  transition:all var(--tr);
}
.fab-btn:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(0,0,0,0.22);}
.fab-btn svg{width:22px;height:22px;}
.fab-label{font-size:9px;font-weight:700;margin-top:1px;letter-spacing:0.04em;}
.fab-tel{background:var(--c-primary);}
.fab-line{background:#06C755;}
.fab-form{background:var(--c-accent);}
.fab.hide-on-contact{opacity:0;pointer-events:none;}

/* ===== Footer ===== */
.footer{background:var(--c-dark);color:#cbd5e1;padding:80px 0 0;}
.footer-inner{display:grid;grid-template-columns:1.3fr 2fr;gap:60px;padding-bottom:48px;}
.foot-brand .brand-logo{width:220px;}
.foot-brand .brand-mark{background:linear-gradient(135deg, var(--c-accent), var(--c-accent-2));color:var(--c-dark);}
.foot-brand .brand-name{color:#fff;}
.foot-brand .brand-sub{color:#94a3b8;}
.foot-brand p{margin-top:20px;font-size:13px;line-height:1.9;color:#94a3b8;}
.foot-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.foot-nav h4{font-size:13px;color:var(--c-accent);margin-bottom:16px;letter-spacing:0.1em;}
.foot-nav ul{display:flex;flex-direction:column;gap:8px;}
.foot-nav a{font-size:13px;color:#cbd5e1;}
.foot-nav a:hover{color:var(--c-accent);}
.foot-tel{font-family:var(--f-en);font-size:22px;color:#fff;font-weight:700;margin-bottom:8px;}
.foot-nav p{font-size:13px;line-height:1.8;}

.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:20px 0;}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.footer-bottom small{font-size:11px;color:#64748b;}
.footer-bottom ul{display:flex;gap:24px;}
.footer-bottom a{font-size:11px;color:#64748b;}
.footer-bottom a:hover{color:var(--c-accent);}

/* ===== Animation ===== */
.fade-up{opacity:0;transform:translateY(24px);transition: opacity 0.8s, transform 0.8s;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ===== SEO landing pages ===== */
.lp-page{background:#fff;}
.lp-hero{
  padding:148px 0 88px;
  background:linear-gradient(135deg,#f8fafc 0%, #eef2f7 100%);
  position:relative;overflow:hidden;
}
.lp-hero::before{
  content:'';position:absolute;right:-8%;top:-25%;width:45%;height:70%;
  background:rgba(232,168,70,0.12);border-radius:50%;
}
.area-hero::before{background:rgba(26,59,92,0.08);}
.lp-hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.35fr 0.65fr;gap:48px;align-items:center;
}
.lp-hero-text h1{
  font-size:clamp(32px,5vw,54px);
  line-height:1.35;color:var(--c-primary);
  font-weight:800;margin:0 0 24px;
}
.lp-hero-text .hl{white-space:normal;}
.lp-hero-text p{
  max-width:720px;font-size:16px;line-height:2;
  color:var(--c-text-2);margin-bottom:34px;
}
.lp-hero-panel{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:34px;
  box-shadow:var(--shadow-lg);
}
.lp-hero-panel span{
  display:block;font-size:12px;font-weight:700;
  letter-spacing:0.14em;color:var(--c-muted);
  margin-bottom:10px;
}
.lp-hero-panel strong{
  display:block;font-size:34px;line-height:1.25;
  color:var(--c-primary);font-weight:800;margin-bottom:14px;
}
.lp-hero-panel p{
  font-size:13px;line-height:1.9;color:var(--c-text-2);
}
.lp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.lp-card{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:32px;
  box-shadow:var(--shadow-sm);
}
.lp-card h3{
  font-size:19px;line-height:1.55;color:var(--c-primary);
  margin-bottom:12px;font-weight:700;
}
.lp-card p{font-size:14px;line-height:1.9;color:var(--c-text-2);}
.lp-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:18px 24px;
}
.lp-list li{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);padding:22px 24px;
  display:flex;flex-direction:column;gap:5px;
}
.lp-list strong{color:var(--c-primary);font-size:15px;}
.lp-list span{color:var(--c-text-2);font-size:13px;line-height:1.8;}
.lp-steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.lp-steps li{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:28px;
}
.lp-steps span{
  display:block;font-family:var(--f-en);font-size:28px;
  font-weight:800;color:var(--c-accent);margin-bottom:10px;
}
.lp-steps strong{display:block;color:var(--c-primary);font-size:17px;margin-bottom:8px;}
.lp-steps p{font-size:13px;line-height:1.8;color:var(--c-text-2);}
.area-tags{
  display:flex;flex-wrap:wrap;gap:12px;
}
.area-tags span{
  padding:10px 16px;border-radius:999px;
  background:var(--c-soft);border:1px solid var(--c-line);
  color:var(--c-primary);font-size:13px;font-weight:700;
}
.lp-case-strip{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
}
.lp-case-link{
  display:flex;flex-direction:column;gap:10px;
  padding:26px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);
}
.lp-case-link:hover{
  border-color:var(--c-accent);box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.lp-case-link span{
  font-size:11px;font-weight:700;letter-spacing:0.12em;
  color:var(--c-accent-2);
}
.lp-case-link strong{
  color:var(--c-primary);font-size:18px;line-height:1.55;
}
.lp-case-link p{
  color:var(--c-text-2);font-size:13px;line-height:1.8;
}
.lp-faq{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;
}
.lp-faq-item{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);padding:22px 24px;
}
.lp-faq-item h3{
  color:var(--c-primary);font-size:15px;line-height:1.6;
  margin-bottom:8px;font-weight:700;
}
.lp-faq-item p{
  color:var(--c-text-2);font-size:13px;line-height:1.85;
}
.lp-cta{
  padding:76px 0;text-align:center;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  color:#fff;
}
.lp-cta h2{
  color:#fff;font-size:clamp(24px,3.5vw,38px);
  line-height:1.5;margin-bottom:14px;font-weight:800;
}
.lp-cta p{
  max-width:720px;margin:0 auto 28px;
  color:rgba(255,255,255,0.86);font-size:15px;line-height:1.9;
}

/* ===== Case study pages ===== */
.case-study-page{background:#fff;}
.case-study-hero{
  padding:148px 0 88px;
  background:linear-gradient(135deg,#f8fafc 0%, #eef2f7 100%);
  position:relative;overflow:hidden;
}
.case-study-hero::before{
  content:'';position:absolute;right:-8%;top:-20%;width:46%;height:72%;
  background:rgba(232,168,70,0.12);border-radius:50%;
}
.case-study-hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.25fr 0.75fr;gap:48px;align-items:center;
}
.case-study-hero h1{
  color:var(--c-primary);font-size:clamp(32px,5vw,54px);
  line-height:1.35;font-weight:800;margin:0 0 22px;
}
.case-study-hero .hl{white-space:normal;}
.case-study-hero p{
  max-width:760px;font-size:16px;line-height:2;
  color:var(--c-text-2);margin-bottom:32px;
}
.case-study-meta{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:30px;
  box-shadow:var(--shadow-lg);
}
.case-study-meta dl{display:flex;flex-direction:column;gap:18px;}
.case-study-meta div{
  padding-bottom:16px;border-bottom:1px dashed var(--c-line);
}
.case-study-meta div:last-child{padding-bottom:0;border-bottom:none;}
.case-study-meta dt{
  font-size:11px;font-weight:700;letter-spacing:0.14em;
  color:var(--c-muted);margin-bottom:5px;
}
.case-study-meta dd{
  color:var(--c-primary);font-size:14px;line-height:1.75;font-weight:700;
}
.case-study-meta a{color:var(--c-accent-2);}
.case-study-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.case-study-block{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:32px;
  box-shadow:var(--shadow-sm);
}
.case-study-block span{
  display:block;font-family:var(--f-en);font-size:28px;
  color:var(--c-accent);font-weight:800;margin-bottom:10px;
}
.case-study-block h2{
  color:var(--c-primary);font-size:20px;line-height:1.5;
  margin-bottom:12px;font-weight:700;
}
.case-study-block p{
  color:var(--c-text-2);font-size:14px;line-height:1.95;
}

/* ============================================================
   Responsive
============================================================ */
@media (max-width: 1100px){
  .nav{display:none;}
  .head-tel{display:none;}
  .hamb{display:flex;}
  .hero-inner{grid-template-columns:1fr;gap:40px;}
  .hero-right{max-width:480px;margin:0 auto;}
  .srv-grid, .rs-grid{grid-template-columns:repeat(2,1fr);}
  .local-grid{grid-template-columns:repeat(2,1fr);}
  .rs-feature{grid-column:span 2;}
  .hero-photo-card{left:0;bottom:16px;}
  .plan-grid{grid-template-columns:repeat(2,1fr);}
  .plan-compare{grid-template-columns:1fr;gap:20px;}
  .plan-c{padding:32px 28px;}
  .works-grid{grid-template-columns:repeat(2,1fr);}
  .work-featured{grid-column:span 2;grid-row:auto;}
  .steps{grid-template-columns:repeat(2,1fr);}
  .story-grid{grid-template-columns:1fr;gap:40px;}
  .contact-grid{grid-template-columns:1fr;}
  .lp-hero-inner{grid-template-columns:1fr;}
  .lp-grid{grid-template-columns:1fr;}
  .lp-case-strip{grid-template-columns:1fr;}
  .lp-steps{grid-template-columns:repeat(2,1fr);}
  .case-study-hero-inner{grid-template-columns:1fr;}
  .case-study-grid{grid-template-columns:1fr;}
  .section{padding:80px 0;}
}
@media (max-width:700px){
  .section{padding:64px 0;}
  .header-inner{gap:14px;}
  .head-cta{gap:10px;}
  .head-cta .btn{padding:10px 16px;font-size:13px;}
  .srv-grid, .rs-grid{grid-template-columns:1fr;}
  .local-grid{grid-template-columns:1fr;}
  .local-card{padding:24px 22px;}
  .rs-feature{grid-column:auto;padding:32px 24px;}
  .rs-feature h3{font-size:22px;}
  .plan-grid, .plan-grid-3, .plan-grid-2{grid-template-columns:1fr;}
  .plan-compare{grid-template-columns:1fr;gap:16px;}
  .plan-c{padding:28px 22px;}
  .plan-c-title{font-size:22px;}
  .pc-amount{font-size:34px;}
  .plan-intro{padding:22px 24px;}
  .plan-intro-lead{font-size:15px;}
  .plan-common{padding:26px 22px;}
  .plan-common h4{font-size:14px;margin-bottom:18px;}
  .plan-common ul{grid-template-columns:1fr;gap:14px;}
  .plan-common li strong{font-size:13.5px;}
  .plan-common-sub{font-size:12.5px;}
  .price-factors{padding:26px 22px;margin-top:24px;}
  .pf-list{grid-template-columns:1fr;gap:14px;}
  .plan-c-scope{padding:14px 16px;}
  .plan-c-scope-list li{font-size:12px;}
  .works-grid{grid-template-columns:1fr;}
  .work-featured{grid-column:auto;}
  .steps{grid-template-columns:1fr;}
  .fi-row{grid-template-columns:1fr;}
  .contact-form{padding:24px;}
  .fi-radio-row{gap:6px;}
  .fi-radio{padding:7px 12px;font-size:12.5px;}
  .fab{right:12px;bottom:12px;flex-direction:row;}
  .fab-btn{width:52px;height:52px;}
  .fab-btn svg{width:20px;height:20px;}
  .fab-label{font-size:8.5px;}
  .hero{padding:110px 0 80px;}
  .brand-logo{width:150px;}
  .hero-stats{grid-template-columns:1fr;gap:16px;}
  .hero-stats li{border-left:2px solid var(--c-accent);padding-left:14px;}
  .hero-right{display:none;}
  .rs-feature{flex-direction:column;gap:24px;}
  .rs-feature-photo{width:160px;}
  .hero-title{font-size:32px;}
  .footer-inner{grid-template-columns:1fr;gap:40px;}
  .foot-nav{grid-template-columns:1fr;gap:24px;}
  .footer-bottom .container{flex-direction:column;text-align:center;}
  .cta-btns{flex-direction:column;}
  .cta-btns .btn{width:100%;}
  .btn-lg{padding:14px 24px;}
  .story-lead{font-size:18px;padding-left:18px;}
  .lp-hero{padding:112px 0 64px;}
  .lp-hero-panel{padding:26px 22px;}
  .lp-hero-panel strong{font-size:27px;}
  .lp-list{grid-template-columns:1fr;}
  .lp-faq{grid-template-columns:1fr;}
  .lp-steps{grid-template-columns:1fr;}
  .lp-card{padding:26px 22px;}
  .lp-cta{text-align:left;}
  .case-study-hero{padding:112px 0 64px;}
  .case-study-meta{padding:24px 22px;}
  .case-study-block{padding:26px 22px;}
}

/* ============================================================
   Sample Case Study Page (sample-case.html)
============================================================ */
.sample-page{background:#fdfcf9;color:var(--c-text);}
.sample-page html{scroll-behavior:smooth;}

/* Sample notice banner */
.sample-banner{
  background:var(--c-primary);color:#fff;
  padding:10px 0;font-size:12px;
  position:sticky;top:0;z-index:60;
  border-bottom:1px solid rgba(255,255,255,0.1);
}
.sample-banner .container{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
}
.sb-label{
  background:var(--c-accent);color:var(--c-dark);
  padding:3px 10px;border-radius:3px;
  font-family:var(--f-en);font-size:10px;font-weight:700;letter-spacing:0.2em;
  flex-shrink:0;
}
.sb-text{flex:1;opacity:0.92;font-size:12px;line-height:1.6;min-width:240px;}
.sb-text strong{color:var(--c-accent);font-weight:700;}
.sb-link{color:var(--c-accent);font-weight:700;font-size:12px;letter-spacing:0.05em;white-space:nowrap;}
.sb-link:hover{opacity:0.75;}

/* Client-style header */
.case-header{
  background:#fff;padding:20px 0;
  border-bottom:1px solid var(--c-line);
}
.case-head-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.case-brand{display:flex;align-items:center;gap:12px;}
.case-brand-mark{
  width:46px;height:46px;border-radius:8px;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  color:var(--c-accent);display:grid;place-items:center;
  font-size:11px;font-weight:700;line-height:1.2;text-align:center;letter-spacing:0.05em;
}
.case-brand-text{display:flex;flex-direction:column;line-height:1.25;}
.case-brand-name{font-size:17px;font-weight:800;color:var(--c-primary);letter-spacing:0.03em;}
.case-brand-sub{font-size:11px;color:var(--c-muted);margin-top:2px;}
.case-nav{display:flex;gap:24px;}
.case-nav a{font-size:13px;color:var(--c-text);font-weight:500;position:relative;padding:6px 0;}
.case-nav a.active{color:var(--c-accent-2);font-weight:700;}
.case-nav a.active::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--c-accent);
}
.case-nav a:hover{color:var(--c-accent-2);}
.case-tel-btn{
  padding:11px 20px;background:var(--c-accent);color:#fff;
  border-radius:var(--radius);font-size:13px;font-weight:700;
  transition:all var(--tr);
}
.case-tel-btn:hover{background:var(--c-accent-2);transform:translateY(-1px);}

/* Breadcrumb */
.case-crumb{background:#faf7f0;padding:12px 0;font-size:12px;color:var(--c-muted);border-bottom:1px solid var(--c-line);}
.case-crumb a{color:var(--c-muted);}
.case-crumb a:hover{color:var(--c-primary);}
.case-crumb span{margin:0 6px;color:var(--c-line-2);}

/* Case hero */
.case-hero{
  padding:60px 0 48px;
  background:linear-gradient(180deg, #fff 0%, #faf7f0 100%);
}
.case-meta{display:flex;gap:10px;align-items:center;margin-bottom:20px;flex-wrap:wrap;}
.case-category{
  background:var(--c-accent);color:#fff;
  padding:5px 14px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:0.1em;
}
.case-category.sub{background:var(--c-primary);}
.case-date{font-size:11px;color:var(--c-muted);font-family:var(--f-en);letter-spacing:0.1em;margin-left:auto;}
.case-title{
  font-size:clamp(24px,3.6vw,36px);font-weight:800;
  color:var(--c-primary);line-height:1.45;letter-spacing:0.02em;
  margin-bottom:20px;
}
.case-title small{
  display:inline-block;margin-top:8px;font-size:0.55em;
  color:var(--c-accent-2);font-weight:600;letter-spacing:0.05em;
}
.case-lead{font-size:15px;line-height:1.95;color:var(--c-text-2);max-width:860px;margin-bottom:36px;}
.case-quick{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px 24px;
  padding:24px 28px;background:#fff;border:1px solid var(--c-line);
  border-left:4px solid var(--c-accent);border-radius:var(--radius);
}
.case-quick div{display:flex;flex-direction:column;gap:4px;}
.case-quick dt{font-size:11px;color:var(--c-muted);letter-spacing:0.1em;}
.case-quick dd{font-size:14px;font-weight:700;color:var(--c-primary);}

/* Case sections */
.case-section{padding:64px 0;border-bottom:1px solid var(--c-line);}
.case-section:last-of-type{border-bottom:none;}
.cs-title{
  font-size:22px;font-weight:700;color:var(--c-primary);
  margin-bottom:28px;padding-left:16px;
  border-left:4px solid var(--c-accent);letter-spacing:0.05em;line-height:1.4;
}
.case-section > .container > p{
  font-size:15px;line-height:2;color:var(--c-text-2);margin-bottom:16px;
}

/* Request list */
.request-list{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:10px 28px;margin-top:24px;
  padding:24px 28px;background:#fff;
  border:1px solid var(--c-line);border-radius:var(--radius);
}
.request-list li{
  position:relative;padding-left:24px;
  font-size:14px;color:var(--c-text);line-height:1.75;
}
.request-list li::before{
  content:'✓';position:absolute;left:0;top:0;
  color:var(--c-accent);font-weight:700;
}

/* Before / After */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.ba-card{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);overflow:hidden;position:relative;
  box-shadow:var(--shadow-sm);
}
.ba-label{
  position:absolute;top:16px;left:16px;z-index:2;
  padding:6px 14px;border-radius:20px;
  font-family:var(--f-en);font-size:11px;font-weight:700;letter-spacing:0.2em;
}
.ba-label.before{background:rgba(0,0,0,0.7);color:#fff;}
.ba-label.after{background:var(--c-accent);color:#fff;}
.ba-img{
  height:240px;display:grid;place-items:center;
  position:relative;overflow:hidden;
}
.ba-img.before-img{background:linear-gradient(135deg,#4a4a4a 0%,#2a2a2a 100%);color:rgba(255,255,255,0.35);}
.ba-img.after-img{background:linear-gradient(135deg,#ede7d6 0%,#d4c9a8 100%);color:rgba(31,58,92,0.4);}
.ba-img::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 10px, transparent 10px 20px);
}
.ba-placeholder{font-size:13px;letter-spacing:0.1em;position:relative;z-index:1;}
.ba-card figcaption{padding:20px 24px;font-size:13px;color:var(--c-text-2);line-height:1.9;}

/* Process timeline */
.process-list{display:flex;flex-direction:column;padding-left:0;list-style:none;}
.process-list li{
  display:grid;grid-template-columns:100px 1fr;gap:28px;
  padding:22px 0;border-bottom:1px dashed var(--c-line);
}
.process-list li:last-child{border-bottom:none;}
.pl-time{
  font-family:var(--f-en);font-size:22px;font-weight:700;
  color:var(--c-accent-2);letter-spacing:0.05em;line-height:1;padding-top:3px;
}
.pl-body{display:flex;flex-direction:column;gap:6px;}
.pl-body strong{font-size:15px;font-weight:700;color:var(--c-primary);}
.pl-body span{font-size:13px;color:var(--c-text-2);line-height:1.85;}

/* Pricing */
.case-price-box{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:32px 36px;box-shadow:var(--shadow-sm);max-width:720px;
}
.cpb-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:18px 0;border-bottom:1px dashed var(--c-line);
}
.cpb-row.total{
  border-bottom:none;padding-top:24px;margin-top:8px;
  border-top:2px solid var(--c-primary);
}
.cpb-label{font-size:14px;color:var(--c-text-2);font-weight:500;}
.cpb-row.total .cpb-label{font-size:16px;font-weight:700;color:var(--c-primary);}
.cpb-amount{
  font-family:var(--f-en);font-size:26px;font-weight:700;
  color:var(--c-primary);letter-spacing:0.02em;white-space:nowrap;
}
.cpb-amount small{font-family:var(--f-sans);font-size:13px;font-weight:600;margin-left:2px;}
.cpb-amount.minus{color:var(--c-accent-2);}
.cpb-row.total .cpb-amount{font-size:32px;color:var(--c-accent-2);}
.cpb-note{
  margin-top:20px;padding-top:18px;
  border-top:1px dashed var(--c-line);
  font-size:12px;color:var(--c-muted);line-height:1.85;
}
.cpb-note strong{color:var(--c-primary);font-weight:700;}

/* Voice / Comment */
.case-voice{
  background:rgba(15,30,58,0.04);
  padding:32px 36px;border-radius:var(--radius-lg);
  border-left:4px solid var(--c-accent);margin-bottom:28px;
}
.case-voice p{font-size:16px;line-height:2.1;color:var(--c-text);margin-bottom:16px;}
.case-voice footer{font-size:12px;color:var(--c-muted);padding-top:12px;border-top:1px solid rgba(31,58,92,0.1);}
.case-comment-staff{
  font-size:14px!important;color:var(--c-text-2)!important;line-height:1.9!important;
  padding:22px 26px;background:#fff;
  border:1px dashed var(--c-line);border-radius:var(--radius);
}
.case-comment-staff strong{color:var(--c-primary);font-weight:700;margin-right:4px;}

/* Related */
.related{background:#faf7f0;}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.rel-card{
  display:flex;flex-direction:column;gap:10px;
  padding:24px 24px 26px;background:#fff;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  transition:all var(--tr);color:inherit;
}
.rel-card:hover{border-color:var(--c-accent);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.rel-tag{
  align-self:flex-start;padding:3px 10px;
  background:rgba(232,168,70,0.15);color:var(--c-accent-2);
  font-size:10px;font-weight:700;letter-spacing:0.1em;border-radius:12px;
}
.rel-card h3{font-size:15px;font-weight:700;color:var(--c-primary);line-height:1.55;}
.rel-card p{font-size:12px;color:var(--c-muted);}

/* CTA */
.case-cta{
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  color:#fff;padding:64px 0;text-align:center;
  position:relative;overflow:hidden;
}
.case-cta::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 80% 30%, rgba(232,168,70,0.15) 0%, transparent 45%);
}
.case-cta .container{position:relative;z-index:1;}
.case-cta h2{font-size:clamp(22px,3vw,30px);font-weight:800;margin-bottom:16px;color:#fff;letter-spacing:0.05em;}
.case-cta p{font-size:15px;line-height:1.95;color:rgba(255,255,255,0.92);margin-bottom:28px;}
.case-cta .cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* Case footer */
.case-footer{background:#1a1e2c;color:#9ca3af;padding:36px 0;}
.case-footer .cf-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cf-brand{display:flex;align-items:center;gap:14px;}
.cf-brand .case-brand-mark{background:linear-gradient(135deg, var(--c-accent), var(--c-accent-2));color:var(--c-dark);}
.cf-brand div{display:flex;flex-direction:column;gap:2px;}
.cf-brand strong{color:#fff;font-size:14px;font-weight:700;}
.cf-brand span{font-size:11px;color:#6b7280;}
.cf-info p{font-size:12px;color:#9ca3af;line-height:1.8;margin:0;}
.case-footer small{font-size:11px;color:#6b7280;}

/* Return banner (bottom) */
.return-banner{
  background:linear-gradient(180deg, var(--c-soft) 0%, #f5f7fa 100%);
  padding:40px 0;border-top:3px solid var(--c-accent);
}
.return-banner .container{
  display:flex;align-items:center;justify-content:space-between;
  gap:28px;flex-wrap:wrap;
}
.rb-text{flex:1;min-width:280px;}
.rb-label{
  display:inline-block;margin-bottom:10px;
  padding:4px 12px;background:var(--c-accent);color:#fff;
  font-family:var(--f-en);font-size:10px;font-weight:700;letter-spacing:0.2em;
  border-radius:3px;
}
.rb-text p{font-size:13px;color:var(--c-text);line-height:1.95;margin:0;}
.rb-text strong{color:var(--c-primary);font-weight:700;}

/* ===== Plan-c sample links (in index.html Plan A) ===== */
.plan-c-samples{
  margin-top:8px;padding-top:20px;
  border-top:1px dashed var(--c-line);
}
.pcs-head{
  font-size:12px;color:var(--c-muted);font-weight:600;
  letter-spacing:0.08em;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.pcs-head::before{
  content:'';width:4px;height:12px;background:var(--c-accent);border-radius:2px;
}
.pcs-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pcs-grid-1{grid-template-columns:1fr;}
.plan-c-sample-link{
  padding:14px 16px;
  border:1.5px solid var(--c-primary);border-radius:var(--radius);
  display:flex;flex-direction:column;gap:4px;
  color:var(--c-primary);text-decoration:none;background:#fff;
  transition:all var(--tr);position:relative;
}
.plan-c-sample-link.alt{border-color:var(--c-accent-2);}
.plan-c-sample-link:hover{
  background:var(--c-primary);color:#fff;
  transform:translateY(-2px);box-shadow:var(--shadow-md);
}
.plan-c-sample-link.alt:hover{background:var(--c-accent-2);}
.psl-cap{
  font-family:var(--f-en);font-size:10px;font-weight:700;
  letter-spacing:0.2em;color:var(--c-accent-2);
}
.plan-c-sample-link.alt .psl-cap{color:var(--c-primary);}
.plan-c-sample-link:hover .psl-cap{color:var(--c-accent);}
.psl-text{
  font-size:13px;font-weight:700;letter-spacing:0.03em;line-height:1.45;
}
.psl-text small{
  display:block;font-size:10.5px;font-weight:500;
  color:var(--c-muted);margin-top:3px;letter-spacing:0;
}
.plan-c-sample-link:hover .psl-text small{color:rgba(255,255,255,0.75);}
.psl-arrow{
  position:absolute;top:14px;right:14px;
  font-family:var(--f-en);font-size:15px;
  transition:transform var(--tr);opacity:0.6;
}
.plan-c-sample-link:hover .psl-arrow{transform:translateX(4px);opacity:1;}

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

/* ===== Sample page responsive ===== */
@media (max-width: 900px){
  .case-head-inner{flex-wrap:wrap;gap:16px;}
  .case-nav{order:3;width:100%;justify-content:space-between;gap:8px;overflow-x:auto;padding-bottom:4px;}
  .case-nav a{font-size:12px;flex-shrink:0;}
  .case-quick{grid-template-columns:repeat(2,1fr);padding:20px 22px;}
  .ba-grid{grid-template-columns:1fr;gap:20px;}
  .request-list{grid-template-columns:1fr;padding:20px 22px;}
  .process-list li{grid-template-columns:80px 1fr;gap:16px;padding:18px 0;}
  .pl-time{font-size:18px;}
  .cpb-row{flex-direction:column;align-items:flex-start;gap:6px;padding:14px 0;}
  .case-price-box{padding:24px 22px;}
  .rel-grid{grid-template-columns:1fr;}
  .case-section{padding:48px 0;}
  .case-footer .cf-inner{flex-direction:column;align-items:flex-start;}
  .return-banner .container{flex-direction:column;align-items:flex-start;}
  .sample-banner .container{gap:10px;}
  .sb-text{font-size:11px;}
}

/* ============================================================
   Demo Site (sample-site.html) — Full Site Preview
============================================================ */

/* ===== Section head (shared in demo) ===== */
.ds-head{margin-bottom:48px;}
.ds-head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.ds-label{
  display:inline-block;font-family:var(--f-en);
  font-size:12px;letter-spacing:0.3em;
  color:var(--c-accent-2);font-weight:700;margin-bottom:10px;
}
.ds-desc{margin-top:12px;font-size:14px;color:var(--c-text-2);line-height:1.9;max-width:680px;}
.ds-more{
  font-size:13px;font-weight:700;color:var(--c-primary);
  border-bottom:2px solid var(--c-accent);padding-bottom:2px;
  transition:color var(--tr);white-space:nowrap;
}
.ds-more:hover{color:var(--c-accent-2);}

/* ===== Demo Hero ===== */
.demo-hero{
  position:relative;padding:90px 0 110px;
  background:linear-gradient(135deg, var(--c-primary) 0%, var(--c-dark) 100%);
  color:#fff;overflow:hidden;
}
.dh-decor{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 15% 25%, rgba(232,168,70,0.15) 0%, transparent 40%),
    radial-gradient(circle at 85% 75%, rgba(232,168,70,0.08) 0%, transparent 45%);
}
.demo-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size:60px 60px;opacity:0.6;
}
.demo-hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;
}
.dh-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:30px;
  background:rgba(232,168,70,0.15);border:1px solid rgba(232,168,70,0.3);
  font-size:12px;color:var(--c-accent);font-weight:600;letter-spacing:0.1em;
  margin-bottom:32px;
}
.dh-chip-dot{width:8px;height:8px;border-radius:50%;background:var(--c-accent);box-shadow:0 0 10px var(--c-accent);}
.dh-title{
  font-size:clamp(32px, 5.4vw, 56px);font-weight:800;line-height:1.35;
  color:#fff;letter-spacing:0.02em;margin-bottom:28px;
}
.dh-accent{color:var(--c-accent);}
.dh-lead{font-size:16px;line-height:2;color:rgba(255,255,255,0.92);margin-bottom:36px;max-width:560px;}
.dh-ctas{display:flex;gap:16px;margin-bottom:44px;flex-wrap:wrap;}
.dh-stats{
  display:grid;grid-template-columns:repeat(3,auto);gap:32px;
  padding-top:28px;border-top:1px solid rgba(255,255,255,0.15);
  justify-content:start;
}
.dh-stats li{display:flex;flex-direction:column;gap:4px;}
.dh-stats strong{font-family:var(--f-en);font-size:30px;font-weight:700;color:var(--c-accent);letter-spacing:0.02em;}
.dh-stats strong small{font-size:18px;margin-left:2px;}
.dh-stats span{font-size:11px;color:rgba(255,255,255,0.7);letter-spacing:0.1em;}

/* Hero right floating cards */
.dh-right{position:relative;height:400px;}
.dh-card{
  position:absolute;background:#fff;color:var(--c-text);
  padding:22px 26px;border-radius:var(--radius-lg);
  display:flex;flex-direction:column;gap:6px;min-width:220px;
  box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,0.4);
}
.dh-card-1{top:20px;left:0;z-index:3;}
.dh-card-2{top:160px;right:0;z-index:4;border-left:3px solid var(--c-accent);}
.dh-card-3{bottom:20px;left:40px;z-index:3;}
.dhc-label{font-family:var(--f-en);font-size:10px;font-weight:700;letter-spacing:0.25em;color:var(--c-accent-2);}
.dh-card strong{font-size:18px;font-weight:800;color:var(--c-primary);line-height:1.4;}
.dhc-meta{font-size:11px;color:var(--c-muted);}

/* ===== Demo Services ===== */
.demo-services{background:#fff;}
.ds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.ds-card{
  padding:32px 28px;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  transition:all var(--tr);display:flex;flex-direction:column;gap:14px;background:#fff;
}
.ds-card:hover{border-color:var(--c-accent);transform:translateY(-4px);box-shadow:var(--shadow-md);}
.ds-num{
  font-family:var(--f-en);font-size:26px;font-weight:700;
  color:var(--c-accent);letter-spacing:0.05em;line-height:1;
}
.ds-card h3{font-size:18px;font-weight:700;color:var(--c-primary);letter-spacing:0.03em;}
.ds-card p{font-size:13.5px;line-height:1.9;color:var(--c-text-2);flex:1;}
.ds-link{
  font-size:12.5px;font-weight:700;color:var(--c-accent-2);
  letter-spacing:0.05em;margin-top:4px;transition:all var(--tr);
}
.ds-link:hover{color:var(--c-primary);}

/* ===== Demo Reasons ===== */
.demo-reasons{background:#faf7f0;}
.dr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.dr-item{
  padding:32px 28px;background:#fff;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  transition:all var(--tr);
}
.dr-item:hover{border-color:var(--c-accent);box-shadow:var(--shadow-sm);}
.dr-num{
  display:inline-block;font-family:var(--f-en);
  font-size:28px;font-weight:700;color:var(--c-accent);
  letter-spacing:0.05em;margin-bottom:10px;
}
.dr-item h3{font-size:17px;font-weight:700;color:var(--c-primary);margin-bottom:10px;line-height:1.55;}
.dr-item p{font-size:13px;line-height:1.95;color:var(--c-text-2);}

/* ===== Demo Pricing ===== */
.demo-pricing{background:#fff;}
.dp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;}
.dp-card{
  position:relative;padding:30px 22px;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);
  text-align:center;transition:all var(--tr);
}
.dp-card:hover{border-color:var(--c-accent);transform:translateY(-3px);box-shadow:var(--shadow-sm);}
.dp-card.featured{
  border:2px solid var(--c-accent);
  background:linear-gradient(180deg,#fff,#faf7f0);
  box-shadow:var(--shadow-sm);
}
.dp-flag{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--c-accent);color:#fff;
  padding:4px 14px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:0.1em;
}
.dp-room{
  font-size:13px;font-weight:700;color:var(--c-primary);letter-spacing:0.1em;
  padding-bottom:12px;margin-bottom:14px;
  border-bottom:1px solid var(--c-line);
}
.dp-amount{
  font-family:var(--f-en);font-size:30px;font-weight:700;
  color:var(--c-primary);line-height:1;letter-spacing:0.02em;
}
.dp-amount small{font-family:var(--f-sans);font-size:13px;color:var(--c-muted);font-weight:500;margin-left:2px;}
.dp-card p{margin-top:10px;font-size:12px;color:var(--c-muted);}
.dp-note{
  padding:20px 24px;background:#faf7f0;
  border-left:3px solid var(--c-accent);border-radius:var(--radius);
  font-size:13px;line-height:1.9;color:var(--c-text-2);
}
.dp-note strong{color:var(--c-primary);font-weight:700;}

/* ===== Demo Cases ===== */
.demo-cases{background:#faf7f0;}
.dc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.dc-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;transition:all var(--tr);display:flex;flex-direction:column;
}
.dc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-accent);}
.dc-thumb{
  height:180px;position:relative;
  display:flex;align-items:flex-end;padding:14px;
  overflow:hidden;
}
.dc-thumb::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 10px, transparent 10px 20px);
}
.thumb-a{background:linear-gradient(135deg,#3a4a5c,#1f2f40);}
.thumb-b{background:linear-gradient(135deg,#5c4a3a,#402f1f);}
.thumb-c{background:linear-gradient(135deg,#4a5c5a,#2f403f);}
.thumb-d{background:linear-gradient(135deg,#4a3a5c,#2f1f40);}
.thumb-e{background:linear-gradient(135deg,#5c5a4a,#40402f);}
.thumb-f{background:linear-gradient(135deg,#3a5c4a,#1f402f);}
.dc-cat{
  position:relative;z-index:1;
  padding:4px 12px;background:var(--c-accent);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:0.1em;
  border-radius:12px;
}
.dc-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:8px;flex:1;}
.dc-body h3{font-size:15px;font-weight:700;color:var(--c-primary);line-height:1.55;}
.dc-meta{font-size:11px;color:var(--c-muted);letter-spacing:0.05em;}
.dc-excerpt{font-size:12.5px;color:var(--c-text-2);line-height:1.85;margin-top:2px;}

/* ===== Demo Voices ===== */
.demo-voices{background:#fff;}
.dv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.dv-card{
  background:#fff;padding:32px 28px;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  position:relative;
}
.dv-card::before{
  content:'"';position:absolute;top:8px;right:20px;
  font-family:var(--f-en);font-size:80px;color:var(--c-accent);opacity:0.25;line-height:1;
}
.dv-rating{color:var(--c-accent);font-size:15px;margin-bottom:14px;letter-spacing:0.1em;}
.dv-card p{font-size:14px;line-height:2;color:var(--c-text);margin-bottom:18px;}
.dv-card footer{font-size:12px;color:var(--c-muted);padding-top:14px;border-top:1px solid var(--c-line);}

/* ===== Demo FAQ ===== */
.demo-faq{background:#faf7f0;}
.demo-faq .container.narrow{max-width:860px;}
.df-list{display:flex;flex-direction:column;gap:10px;}
.df-item{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius);overflow:hidden;
  transition:all var(--tr);
}
.df-item[open]{border-color:var(--c-accent);box-shadow:var(--shadow-sm);}
.df-item summary{
  padding:20px 24px;padding-right:56px;
  font-size:15px;font-weight:700;color:var(--c-primary);
  cursor:pointer;list-style:none;position:relative;
  display:flex;align-items:center;gap:12px;
}
.df-item summary::-webkit-details-marker{display:none;}
.df-item summary::before{
  content:'Q';
  width:28px;height:28px;flex-shrink:0;
  background:var(--c-accent);color:#fff;
  display:grid;place-items:center;border-radius:50%;
  font-family:var(--f-en);font-size:14px;font-weight:700;
}
.df-item summary::after{
  content:'+';position:absolute;right:22px;top:50%;transform:translateY(-50%);
  font-size:22px;color:var(--c-accent);transition:transform var(--tr);
}
.df-item[open] summary::after{transform:translateY(-50%) rotate(45deg);}
.df-answer{
  padding:0 24px 22px 64px;
  font-size:14px;line-height:1.95;color:var(--c-text-2);
}

/* ============================================================
   Demo Site Responsive
============================================================ */
@media (max-width: 1024px){
  .demo-hero-inner{grid-template-columns:1fr;gap:60px;}
  .dh-right{height:360px;max-width:480px;margin:0 auto;width:100%;}
  .ds-grid{grid-template-columns:repeat(2,1fr);}
  .dr-grid, .dp-grid, .dc-grid, .dv-grid{grid-template-columns:repeat(2,1fr);}
  .ds-head-row{flex-direction:column;align-items:flex-start;gap:16px;}
}
@media (max-width: 700px){
  .demo-hero{padding:64px 0 80px;}
  .dh-title{font-size:30px;}
  .dh-stats{grid-template-columns:1fr;gap:16px;padding-top:24px;}
  .dh-right{height:auto;display:none;}
  .ds-grid, .dr-grid, .dp-grid, .dc-grid, .dv-grid{grid-template-columns:1fr;}
  .df-item summary{font-size:14px;padding:16px 20px;padding-right:50px;gap:10px;}
  .df-answer{padding:0 20px 18px 54px;font-size:13px;}
  .demo-hero .dh-ctas{flex-direction:column;}
  .demo-hero .dh-ctas .btn{width:100%;}
}

/* ============================================================
   Cafe Sample Site (sample-site-2.html)
   — 余白多め・ビジュアル重視・編集デザイン
============================================================ */

.cafe-site{
  --cafe-cream: #faf5ee;
  --cafe-paper: #fdfaf3;
  --cafe-coffee: #2a1f15;
  --cafe-coffee-2: #3d2914;
  --cafe-sand: #e8dcc4;
  --cafe-sand-deep: #c4b294;
  --cafe-text: #3a2e22;
  --cafe-muted: #8a7860;
  --cafe-gold: #b89653;
  --cafe-line: #e6dcc8;
  background: var(--cafe-cream);
  color: var(--cafe-text);
  font-family: var(--f-sans);
}
.cafe-site .container{max-width:1140px;}
.cafe-site .container.narrow{max-width:760px;}

/* Sample banner override (warmer tone) */
.cafe-site .sample-banner{background:var(--cafe-coffee);}
.cafe-site .sb-label{background:var(--cafe-gold);color:var(--cafe-coffee);}
.cafe-site .sb-text strong{color:var(--cafe-gold);}
.cafe-site .sb-link{color:var(--cafe-gold);}

/* ===== Cafe Header ===== */
.cafe-header{
  background:transparent;padding:32px 0 24px;
  position:sticky;top:42px;z-index:30;
  backdrop-filter: blur(8px);
  background:rgba(250,245,238,0.85);
  border-bottom:1px solid var(--cafe-line);
}
.cafe-head-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;}
.cafe-brand{display:flex;flex-direction:column;line-height:1.2;color:inherit;}
.cafe-brand-name{
  font-family:'Cormorant Garamond', serif;
  font-size:32px;font-weight:500;color:var(--cafe-coffee);
  letter-spacing:0.18em;line-height:1;
}
.cafe-brand-sub{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:11px;color:var(--cafe-muted);letter-spacing:0.1em;margin-top:6px;
}
.cafe-nav{display:flex;gap:30px;}
.cafe-nav a{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:15px;color:var(--cafe-coffee);letter-spacing:0.1em;
  position:relative;padding:6px 0;
}
.cafe-nav a:hover{color:var(--cafe-gold);}

/* ===== HERO ===== */
.cafe-hero{
  padding:80px 0 120px;background:var(--cafe-cream);
  position:relative;overflow:hidden;
}
.cafe-hero-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.ch-eyebrow{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:14px;color:var(--cafe-gold);letter-spacing:0.15em;
  margin-bottom:24px;
}
.ch-title{
  font-family:'Noto Serif JP', serif;font-weight:500;
  font-size:clamp(38px, 5.4vw, 64px);line-height:1.55;
  color:var(--cafe-coffee);letter-spacing:0.05em;
  margin-bottom:36px;
}
.ch-title em{font-style:normal;color:var(--cafe-gold);}
.ch-lead{
  font-size:15px;line-height:2.1;color:var(--cafe-text);
  margin-bottom:32px;max-width:460px;
}
.ch-meta{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:13px;color:var(--cafe-muted);letter-spacing:0.05em;
  padding-top:24px;border-top:1px solid var(--cafe-line);max-width:460px;
}
.ch-visual{position:relative;height:520px;}
.ch-img{
  position:absolute;inset:0;margin:0;
  border-radius:4px;overflow:hidden;
  background:
    radial-gradient(circle at 30% 35%, rgba(184,150,83,0.35) 0%, transparent 50%),
    linear-gradient(135deg, var(--cafe-sand) 0%, var(--cafe-coffee-2) 100%);
}
.ch-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  object-position:65% center;
}
.ch-badge{
  position:absolute;bottom:-30px;right:-20px;
  width:110px;height:110px;border-radius:50%;
  background:var(--cafe-coffee);color:var(--cafe-cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond', serif;
  letter-spacing:0.15em;
  border:2px solid var(--cafe-cream);
  box-shadow:0 8px 28px rgba(42,31,21,0.25);
}
.cb-since{font-size:11px;font-style:italic;letter-spacing:0.25em;}
.cb-year{font-size:32px;font-weight:500;line-height:1;margin-top:4px;}

/* ===== Section base ===== */
.cafe-section{padding:120px 0;}
.cafe-section.concept{padding:140px 0;}
.cs2-label{
  display:inline-block;font-family:'Cormorant Garamond', serif;
  font-style:italic;font-size:14px;color:var(--cafe-gold);
  letter-spacing:0.15em;margin-bottom:18px;
}
.cs2-title{
  font-family:'Noto Serif JP', serif;font-weight:500;
  font-size:clamp(28px, 4vw, 44px);line-height:1.6;
  color:var(--cafe-coffee);letter-spacing:0.06em;
  margin-bottom:0;
}
.cs2-title.small{font-size:clamp(24px, 3vw, 34px);}
.cs2-title.light{color:var(--cafe-cream);}
.cs2-head{margin-bottom:60px;}
.cs2-head.center{text-align:center;}

/* ===== Concept ===== */
.concept{background:var(--cafe-paper);}
.concept .cs2-title{margin-bottom:50px;}
.concept-body p{
  font-size:16px;line-height:2.3;color:var(--cafe-text);
  margin-bottom:22px;
}
.cafe-pull{
  margin-top:48px;padding:32px 0;
  border-top:1px solid var(--cafe-sand-deep);
  border-bottom:1px solid var(--cafe-sand-deep);
  font-family:'Noto Serif JP', serif;
  font-size:22px;text-align:center;color:var(--cafe-gold);
  letter-spacing:0.2em;line-height:1.8;font-weight:500;
}

/* ===== Menu ===== */
.menu{background:var(--cafe-cream);}
.menu-block{margin-bottom:56px;}
.menu-cat{
  font-family:'Cormorant Garamond', serif;
  font-size:22px;font-weight:500;
  color:var(--cafe-gold);letter-spacing:0.25em;
  text-transform:uppercase;
  padding-bottom:14px;margin-bottom:20px;
  border-bottom:1px solid var(--cafe-line);
}
.menu-items{display:flex;flex-direction:column;}
.menu-items li{
  display:flex;align-items:baseline;gap:12px;
  padding:14px 0;
  font-size:15px;color:var(--cafe-text);
}
.mi-name{flex-shrink:0;font-weight:500;letter-spacing:0.05em;}
.mi-dots{
  flex:1;height:1px;
  background-image:radial-gradient(circle, var(--cafe-sand-deep) 1px, transparent 1.5px);
  background-size:6px 1px;background-position:0 50%;background-repeat:repeat-x;
  align-self:center;opacity:0.7;
}
.mi-price{
  font-family:'Cormorant Garamond', serif;
  font-size:18px;font-weight:500;color:var(--cafe-coffee);
  letter-spacing:0.05em;flex-shrink:0;
}
.menu-note{
  margin-top:28px;padding:16px 20px;
  font-size:12px;color:var(--cafe-muted);line-height:1.95;
  background:var(--cafe-paper);border-left:2px solid var(--cafe-gold);
}

/* ===== Care (alternating editorial) ===== */
.care{background:var(--cafe-paper);}
.care-row{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;margin-bottom:100px;
}
.care-row:last-child{margin-bottom:0;}
.care-row.reverse{direction:rtl;}
.care-row.reverse > *{direction:ltr;}
.care-img{
  height:380px;border-radius:4px;position:relative;overflow:hidden;
}
.care-img::after{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(0,0,0,0.03) 0 1px, transparent 1px 14px);
}
.care-img-1{background:linear-gradient(135deg, var(--cafe-coffee-2) 0%, #6b4a2c 100%);}
.care-img-2{background:linear-gradient(135deg, var(--cafe-sand-deep) 0%, var(--cafe-sand) 100%);}
.care-img-3{background:linear-gradient(135deg, #8c7a5e 0%, var(--cafe-coffee-2) 100%);}
.ci-num{
  position:absolute;top:24px;left:28px;
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:48px;color:rgba(250,245,238,0.85);letter-spacing:0.05em;
}
.care-text h3{
  font-family:'Noto Serif JP', serif;font-weight:500;
  font-size:24px;color:var(--cafe-coffee);
  letter-spacing:0.08em;margin-bottom:20px;
}
.care-text p{
  font-size:15px;line-height:2.2;color:var(--cafe-text);
}

/* ===== Gallery ===== */
.gallery{background:var(--cafe-cream);}
.gal-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-template-rows:clamp(280px, 36vw, 400px) clamp(190px, 22vw, 260px);
  gap:14px;margin-bottom:32px;
}
.gal{
  margin:0;border-radius:4px;position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--cafe-sand-deep) 0%, var(--cafe-coffee-2) 100%);
}
.gal img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform 0.7s ease, filter 0.7s ease;
}
.gal:hover img{transform:scale(1.03);}
/* Mosaic: 1 wide hero on top + 3 details on bottom */
.gal-a{grid-column:1/4;grid-row:1;}   /* 上段：ワイドの空間ショット */
.gal-b{grid-column:1;grid-row:2;}     /* 下段左：ディテール */
.gal-c{grid-column:2;grid-row:2;}     /* 下段中：ディテール */
.gal-d{grid-column:3;grid-row:2;}     /* 下段右：ディテール（外観など） */
.gal-note{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  text-align:center;font-size:14px;color:var(--cafe-muted);
  letter-spacing:0.08em;
}

/* ===== Voices ===== */
.voices{background:var(--cafe-paper);}
.cafe-voices{display:flex;flex-direction:column;gap:48px;}
.cafe-voices blockquote{
  position:relative;padding:0 0 0 32px;
  border-left:1px solid var(--cafe-gold);
}
.cafe-voices blockquote p{
  font-family:'Noto Serif JP', serif;font-weight:400;
  font-size:18px;line-height:2.2;color:var(--cafe-coffee);
  letter-spacing:0.05em;margin-bottom:16px;
}
.cafe-voices blockquote footer{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:13px;color:var(--cafe-muted);letter-spacing:0.1em;
}

/* ===== FAQ (cafe) ===== */
.cafe-faq{display:flex;flex-direction:column;gap:0;}
.cafe-faq details{
  padding:24px 0;border-bottom:1px solid var(--cafe-line);
}
.cafe-faq details:first-child{border-top:1px solid var(--cafe-line);}
.cafe-faq summary{
  font-family:'Noto Serif JP', serif;font-weight:500;
  font-size:16px;color:var(--cafe-coffee);
  cursor:pointer;list-style:none;
  display:flex;align-items:center;gap:16px;
  letter-spacing:0.05em;
  position:relative;padding-right:36px;
}
.cafe-faq summary::-webkit-details-marker{display:none;}
.cafe-faq summary::before{
  content:'+';
  font-family:'Cormorant Garamond', serif;font-weight:500;
  font-size:24px;color:var(--cafe-gold);
  width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform 0.3s;
}
.cafe-faq details[open] summary::before{transform:rotate(45deg);}
.cafe-faq details p{
  margin-top:16px;padding-left:40px;
  font-size:14px;line-height:2;color:var(--cafe-text);
}

/* ===== Visit ===== */
.cafe-visit{
  padding:120px 0;background:var(--cafe-coffee);color:var(--cafe-cream);
}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.cafe-visit .cs2-label{color:var(--cafe-gold);}
.cafe-visit .cs2-title{color:var(--cafe-cream);margin-bottom:40px;}
.visit-list{display:flex;flex-direction:column;}
.visit-list div{
  display:grid;grid-template-columns:120px 1fr;gap:20px;
  padding:18px 0;border-bottom:1px solid rgba(250,245,238,0.15);
}
.visit-list dt{
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:13px;color:var(--cafe-gold);letter-spacing:0.1em;
}
.visit-list dd{font-size:14px;color:var(--cafe-cream);line-height:1.85;}
.visit-map{
  height:400px;border-radius:4px;
  background:linear-gradient(135deg, #4a3b2a 0%, var(--cafe-coffee-2) 100%);
  position:relative;display:grid;place-items:center;overflow:hidden;
  border:1px solid rgba(250,245,238,0.1);
}
.visit-map::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(250,245,238,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(250,245,238,0.04) 1px, transparent 1px);
  background-size:30px 30px;
}
.vm-mark{
  position:relative;z-index:1;
  font-family:'Cormorant Garamond', serif;font-weight:500;
  font-size:22px;color:var(--cafe-gold);letter-spacing:0.2em;
  padding:14px 28px;border:1px solid var(--cafe-gold);
  background:var(--cafe-coffee);
}

/* ===== Cafe Footer ===== */
.cafe-footer{
  background:var(--cafe-cream);padding:60px 0 36px;
  border-top:1px solid var(--cafe-line);text-align:center;
}
.cf2-inner{display:flex;flex-direction:column;align-items:center;gap:18px;}
.cf2-msg{
  font-family:'Noto Serif JP', serif;font-weight:400;
  font-size:16px;color:var(--cafe-coffee);letter-spacing:0.1em;
}
.cafe-footer small{font-size:11px;color:var(--cafe-muted);letter-spacing:0.05em;}

/* Return banner override for cafe */
.cafe-site .return-banner{
  background:var(--cafe-paper);border-top:1px solid var(--cafe-gold);
}
.cafe-site .rb-label{background:var(--cafe-gold);color:var(--cafe-coffee);}
.cafe-site .rb-text strong{color:var(--cafe-coffee);}
.cafe-site .return-banner .btn-primary{
  background:var(--cafe-coffee);color:var(--cafe-cream);box-shadow:none;
}
.cafe-site .return-banner .btn-primary:hover{background:var(--cafe-coffee-2);}

/* ============================================================
   Cafe Site Responsive
============================================================ */
@media (max-width:1024px){
  .cafe-hero-inner, .care-row, .visit-grid{grid-template-columns:1fr;gap:60px;}
  .care-row.reverse{direction:ltr;}
  .ch-visual{height:380px;max-width:480px;margin:0 auto;width:100%;}
  .ch-badge{right:0;}
  .gal-grid{
    grid-template-rows:clamp(240px, 32vw, 320px) clamp(160px, 18vw, 200px);
    gap:12px;
  }
}
@media (max-width:700px){
  .cafe-header{padding:18px 0;top:64px;}
  .cafe-nav{display:none;}
  .cafe-hero{padding:48px 0 80px;}
  .cafe-hero-inner{gap:48px;}
  .ch-title{font-size:34px;}
  .ch-visual{height:280px;}
  .ch-badge{width:88px;height:88px;bottom:-20px;}
  .cb-year{font-size:24px;}
  .cafe-section{padding:72px 0;}
  .cafe-section.concept{padding:80px 0;}
  .cs2-title{font-size:24px;}
  .care-row{gap:32px;margin-bottom:64px;}
  .care-img{height:240px;}
  .gal-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:auto;grid-auto-rows:180px;
  }
  .gal-a, .gal-b, .gal-c, .gal-d{grid-column:auto;grid-row:auto;}
  .gal-a{grid-column:span 2;height:240px;}    /* 上段ワイド維持 */
  .gal-d{grid-column:span 2;height:180px;}    /* 下段最後を1枚で見せる */
  .cafe-visit{padding:72px 0;}
  .visit-grid{gap:40px;}
  .visit-map{height:260px;}
  .visit-list div{grid-template-columns:90px 1fr;gap:14px;}
  .menu-items li{flex-wrap:nowrap;font-size:14px;}
  .mi-price{font-size:16px;}
  .cafe-voices blockquote p{font-size:16px;}
}

/* ============================================================
   Cafe Sample Site — additions for real-store feel
============================================================ */

/* 店主signature in concept */
.cafe-sign{
  margin-top:36px;text-align:right;
  font-family:'Noto Serif JP', serif;
}
.cafe-sign .cs-line{
  display:block;font-size:14px;color:var(--cafe-coffee);
  font-weight:500;letter-spacing:0.1em;
}
.cafe-sign small{
  display:block;margin-top:8px;
  font-family:var(--f-sans);font-size:11px;
  color:var(--cafe-muted);letter-spacing:0.05em;
  line-height:1.7;
}

/* 今月のおすすめ box (in Menu) */
.menu-rec{
  margin:48px 0 28px;padding:30px 34px;
  background:linear-gradient(135deg, var(--cafe-paper) 0%, #f3ead8 100%);
  border-left:3px solid var(--cafe-gold);
  border-radius:2px;
}
.mr-label{
  display:inline-block;
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:12px;color:var(--cafe-gold);letter-spacing:0.2em;
  margin-bottom:10px;
}
.menu-rec h4{
  font-family:'Noto Serif JP', serif;font-weight:500;
  font-size:20px;color:var(--cafe-coffee);
  margin-bottom:14px;letter-spacing:0.08em;
}
.menu-rec p{
  font-size:14px;line-height:2.05;color:var(--cafe-text);
  margin-bottom:14px;
}
.mr-sign{
  text-align:right;font-size:12px!important;color:var(--cafe-muted)!important;
  margin-bottom:0!important;letter-spacing:0.05em;
  font-family:'Cormorant Garamond', serif;font-style:italic;
}

/* Visit list - sub note for 不定休 etc. */
.visit-list dd small{
  display:block;margin-top:4px;
  font-size:11px;color:var(--cafe-sand-deep);letter-spacing:0.02em;line-height:1.6;
}

/* Visit Instagram note */
.visit-sns{
  margin-top:24px;padding-top:18px;
  border-top:1px solid rgba(250,245,238,0.15);
  font-family:'Cormorant Garamond', serif;font-style:italic;
  font-size:13px;color:var(--cafe-gold);letter-spacing:0.05em;
  line-height:1.85;
}

/* Hero meta line height adjustment for 2 lines */
.cafe-site .ch-meta{line-height:1.9;}

/* Mobile tweaks */
@media (max-width:700px){
  .menu-rec{padding:24px 22px;}
  .menu-rec h4{font-size:18px;}
  .visit-list div{grid-template-columns:96px 1fr;}
}

/* ============================================================
   sample-site.html — Hero image + Photos section
============================================================ */

/* ===== Hero image (replaces 3 floating cards) ===== */
.dh-hero-img{
  position:absolute;inset:0;margin:0;
  border-radius:12px;overflow:hidden;
  background:linear-gradient(135deg, #4a5260, #1f2730);
  box-shadow:0 24px 60px rgba(0,0,0,0.4);
}
.dh-hero-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(15,30,58,0.18) 0%, transparent 55%);
  pointer-events:none;z-index:1;
}
.dh-hero-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.dh-card-overlay{
  position:absolute!important;
  bottom:-22px!important;left:-26px!important;
  top:auto!important;right:auto!important;
  z-index:5;
  background:#fff!important;color:var(--c-text)!important;
  border-left:3px solid var(--c-accent)!important;
}
.dh-card-overlay .dhc-label{color:var(--c-accent-2);}
.dh-card-overlay strong{color:var(--c-primary);}

/* ===== Photos section (Before / After + 作業のようす) ===== */
.site-photos{background:var(--c-soft);}
.sp-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.sp-card{
  margin:0;background:#fff;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;position:relative;
  transition:all var(--tr);
  display:flex;flex-direction:column;
}
.sp-card:hover{
  box-shadow:var(--shadow-md);transform:translateY(-3px);
  border-color:var(--c-accent);
}
.sp-tag{
  position:absolute;top:16px;left:16px;z-index:2;
  padding:6px 16px;border-radius:20px;
  font-family:var(--f-en);font-size:11px;font-weight:700;letter-spacing:0.2em;
  color:#fff;
}
.sp-tag.before{background:rgba(15,30,58,0.85);}
.sp-tag.after{background:var(--c-accent);color:var(--c-dark);}
.sp-img{
  aspect-ratio:16/10;
  background:linear-gradient(135deg, #6b7280 0%, #374151 100%);
  overflow:hidden;position:relative;
}
.sp-card.sp-ba .sp-img{
  background:linear-gradient(135deg, #4a5260 0%, #2d3540 100%);
}
.sp-img img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform 0.6s ease;
}
.sp-card:hover .sp-img img{transform:scale(1.04);}
.sp-card figcaption{
  padding:20px 24px 22px;
  display:flex;flex-direction:column;gap:6px;flex:1;
}
.sp-card figcaption strong{
  font-size:15px;font-weight:700;color:var(--c-primary);letter-spacing:0.03em;
}
.sp-card figcaption span{
  font-size:13px;color:var(--c-text-2);line-height:1.85;
}

/* Responsive */
@media (max-width:1024px){
  .sp-grid{gap:20px;}
}
@media (max-width:700px){
  .sp-grid{grid-template-columns:1fr;gap:16px;}
  .sp-img{aspect-ratio:16/11;}
  .dh-card-overlay{
    bottom:-18px!important;left:50%!important;
    transform:translateX(-50%);
  }
}

/* ============================================================
   Builder Sample Site (sample-site-cms.html)
   — 工務店業態 ／ CMSで自社更新する見本
============================================================ */

.bs-site{
  --bs-wood: #8b6f47;
  --bs-wood-deep: #5a4a30;
  --bs-cream: #faf7f2;
  background:#fff;color:var(--c-text);
}

/* ===== Hero ===== */
.bs-hero{
  position:relative;padding:80px 0 100px;
  background:linear-gradient(135deg, var(--c-primary) 0%, var(--c-dark) 100%);
  color:#fff;overflow:hidden;
}
.bs-hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 12% 22%, rgba(232,168,70,0.18) 0%, transparent 42%),
    radial-gradient(circle at 88% 78%, rgba(232,168,70,0.10) 0%, transparent 45%);
}
.bs-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size:50px 50px;opacity:0.7;
}
.bs-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:center;}
.bsh-eyebrow{
  display:inline-block;padding:6px 16px;
  background:rgba(232,168,70,0.15);
  border:1px solid rgba(232,168,70,0.3);
  color:var(--c-accent);font-size:12px;font-weight:600;
  letter-spacing:0.15em;border-radius:20px;margin-bottom:28px;
}
.bsh-title{
  font-size:clamp(32px, 5.4vw, 56px);font-weight:800;line-height:1.4;
  color:#fff;letter-spacing:0.04em;margin-bottom:28px;
}
.bsh-accent{color:var(--c-accent);}
.bsh-lead{
  font-size:16px;line-height:2;color:rgba(255,255,255,0.92);
  margin-bottom:36px;max-width:580px;
}
.bsh-ctas{display:flex;gap:16px;flex-wrap:wrap;}

/* Event card on hero right */
.bsh-side{position:relative;}
.bsh-card-event{
  background:#fff;color:var(--c-text);
  padding:28px 30px;border-radius:var(--radius-lg);
  border-top:4px solid var(--c-accent);
  box-shadow:0 24px 60px rgba(0,0,0,0.35);
}
.bshc-tag{
  display:inline-block;padding:4px 12px;
  background:var(--c-accent);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:0.15em;
  border-radius:12px;margin-bottom:14px;
}
.bsh-card-event h3{
  font-size:18px;font-weight:800;color:var(--c-primary);
  line-height:1.55;margin-bottom:18px;
}
.bsh-card-event dl{margin-bottom:18px;}
.bsh-card-event dl div{
  display:grid;grid-template-columns:50px 1fr;gap:14px;
  padding:8px 0;font-size:13px;
  border-bottom:1px dashed var(--c-line);
}
.bsh-card-event dl div:last-child{border-bottom:none;}
.bsh-card-event dt{color:var(--c-muted);letter-spacing:0.1em;}
.bsh-card-event dd{color:var(--c-text);font-weight:500;line-height:1.6;}
.bshc-link{
  font-size:13px;font-weight:700;color:var(--c-accent-2);
  letter-spacing:0.05em;border-bottom:2px solid var(--c-accent);
  padding-bottom:2px;
}
.bshc-link:hover{color:var(--c-primary);}

/* ===== CMS Tag (key indicator) ===== */
.cms-tag{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;padding:6px 14px;
  background:rgba(232,168,70,0.12);
  border:1px solid rgba(232,168,70,0.4);
  color:var(--c-accent-2);
  font-size:12px;font-weight:600;letter-spacing:0.05em;
  border-radius:20px;
}
.cms-tag-ico{
  display:inline-grid;place-items:center;
  width:16px;height:16px;border-radius:50%;
  background:var(--c-accent);color:#fff;
  font-size:10px;font-weight:700;line-height:1;
}

/* ===== Services ===== */
.bs-services{background:#fff;}
.bss-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.bss-card{
  padding:32px 28px;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  background:#fff;transition:all var(--tr);
  display:flex;flex-direction:column;gap:14px;
}
.bss-card:hover{border-color:var(--c-accent);transform:translateY(-3px);box-shadow:var(--shadow-sm);}
.bss-num{
  font-family:var(--f-en);font-size:24px;font-weight:700;
  color:var(--c-accent);letter-spacing:0.05em;line-height:1;
}
.bss-card h3{font-size:18px;font-weight:700;color:var(--c-primary);}
.bss-card p{font-size:13.5px;line-height:1.95;color:var(--c-text-2);}

/* ===== NEWS list ===== */
.bs-news{background:var(--c-soft);}
.bs-news-list{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);overflow:hidden;
  list-style:none;padding:0;
}
.bs-news-list li{
  display:grid;
  grid-template-columns: 110px 110px 1fr auto;
  align-items:center;gap:20px;
  padding:20px 28px;
  border-bottom:1px solid var(--c-line);
  transition:background var(--tr);
}
.bs-news-list li:last-child{border-bottom:none;}
.bs-news-list li:hover{background:var(--c-soft);}
.news-date{
  font-family:var(--f-en);font-size:14px;font-weight:600;
  color:var(--c-muted);letter-spacing:0.05em;
}
.news-cat{
  display:inline-block;padding:4px 10px;border-radius:12px;
  font-size:11px;font-weight:700;letter-spacing:0.05em;text-align:center;
}
.news-cat-event{background:rgba(232,168,70,0.18);color:var(--c-accent-2);}
.news-cat-info{background:rgba(15,30,58,0.08);color:var(--c-primary);}
.news-cat-works{background:rgba(16,185,129,0.12);color:#0e6b51;}
.news-cat-blog{background:rgba(99,102,241,0.12);color:#3f3fb8;}
.news-cat-staff{background:rgba(180,90,90,0.12);color:#8c3838;}
.news-title{
  font-size:14.5px;color:var(--c-primary);font-weight:500;
  line-height:1.65;letter-spacing:0.02em;
}
.news-title:hover{color:var(--c-accent-2);}
.news-new{
  font-family:var(--f-en);font-size:10px;font-weight:700;
  letter-spacing:0.15em;color:#fff;background:var(--c-accent);
  padding:3px 8px;border-radius:3px;
}

/* ===== WORKS grid ===== */
.bs-works{background:#fff;}
.bs-works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.bsw-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;transition:all var(--tr);
  display:flex;flex-direction:column;
}
.bsw-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-accent);}
.bsw-thumb{
  aspect-ratio:4/3;position:relative;overflow:hidden;
}
.bsw-thumb::after{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 14px);
}
.thumb-w1{background:linear-gradient(135deg, #6b4d2e, #3d2914);}
.thumb-w2{background:linear-gradient(135deg, #5a4a30, #2a1f15);}
.thumb-w3{background:linear-gradient(135deg, #8b7456, #5a4a30);}
.thumb-w4{background:linear-gradient(135deg, #4a4a52, #1f1f2a);}
.thumb-w5{background:linear-gradient(135deg, #7a6043, #3a2c1c);}
.thumb-w6{background:linear-gradient(135deg, #5c5040, #2a221a);}
.bsw-body{padding:22px 24px;display:flex;flex-direction:column;gap:8px;flex:1;}
.bsw-cat{
  display:inline-block;padding:3px 10px;
  background:rgba(15,30,58,0.08);color:var(--c-primary);
  font-size:11px;font-weight:700;letter-spacing:0.05em;
  border-radius:12px;align-self:flex-start;
}
.bsw-card h3{font-size:16px;font-weight:700;color:var(--c-primary);line-height:1.55;letter-spacing:0.02em;}
.bsw-meta{font-size:12px;color:var(--c-muted);}

/* ===== BLOG grid ===== */
.bs-blog{background:var(--c-soft);}
.bs-blog-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.bsb-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;transition:all var(--tr);
  display:flex;flex-direction:column;
}
.bsb-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--c-accent);}
.bsb-thumb{
  aspect-ratio:5/3;position:relative;overflow:hidden;
}
.bsb-thumb::after{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 12px);
}
.thumb-b1{background:linear-gradient(135deg, #1f3a5c, #0f1e3a);}
.thumb-b2{background:linear-gradient(135deg, #c9a876, #8b6f47);}
.thumb-b3{background:linear-gradient(135deg, #6b8a6b, #2f4a2f);}
.thumb-b4{background:linear-gradient(135deg, #5a4a3a, #2a1f15);}
.bsb-body{padding:18px 20px;display:flex;flex-direction:column;gap:8px;flex:1;}
.bsb-cat{
  display:inline-block;padding:3px 10px;
  background:rgba(232,168,70,0.18);color:var(--c-accent-2);
  font-size:10px;font-weight:700;letter-spacing:0.05em;
  border-radius:12px;align-self:flex-start;
}
.bsb-card h3{font-size:14px;font-weight:700;color:var(--c-primary);line-height:1.55;letter-spacing:0.02em;flex:1;}
.bsb-meta{font-size:11px;color:var(--c-muted);font-family:var(--f-en);letter-spacing:0.03em;}

/* ===== FAQ (builder) ===== */
.bs-faq{background:#fff;}
.bs-faq-list{display:flex;flex-direction:column;gap:8px;}
.bs-faq details{
  background:var(--c-soft);border:1px solid var(--c-line);
  border-radius:var(--radius);overflow:hidden;
  transition:all var(--tr);
}
.bs-faq details[open]{border-color:var(--c-accent);background:#fff;}
.bs-faq summary{
  padding:20px 24px;padding-right:54px;
  font-size:15px;font-weight:700;color:var(--c-primary);
  cursor:pointer;list-style:none;position:relative;
  display:flex;align-items:center;gap:14px;letter-spacing:0.03em;
}
.bs-faq summary::-webkit-details-marker{display:none;}
.bs-faq summary::before{
  content:'Q';
  width:26px;height:26px;flex-shrink:0;
  background:var(--c-accent);color:#fff;
  display:grid;place-items:center;border-radius:50%;
  font-family:var(--f-en);font-size:13px;font-weight:700;
}
.bs-faq summary::after{
  content:'+';position:absolute;right:22px;top:50%;transform:translateY(-50%);
  font-size:22px;color:var(--c-accent);transition:transform var(--tr);
}
.bs-faq details[open] summary::after{transform:translateY(-50%) rotate(45deg);}
.bs-faq details p{
  padding:0 24px 22px 64px;
  font-size:14px;line-height:1.95;color:var(--c-text-2);
}
.bs-faq details a{color:var(--c-accent-2);border-bottom:1px solid var(--c-accent);}

/* ============================================================
   Builder Site Responsive
============================================================ */
@media (max-width:1024px){
  .bs-hero-inner{grid-template-columns:1fr;gap:48px;}
  .bsh-side{max-width:480px;}
  .bss-grid{grid-template-columns:repeat(2,1fr);}
  .bs-works-grid{grid-template-columns:repeat(2,1fr);}
  .bs-blog-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:700px){
  .bs-hero{padding:56px 0 80px;}
  .bsh-title{font-size:28px;}
  .bs-news-list li{
    grid-template-columns:1fr;gap:8px;padding:18px 20px;
  }
  .bs-news-list .news-date{font-size:12px;}
  .bs-news-list .news-cat{justify-self:start;}
  .bs-news-list .news-new{justify-self:start;}
  .bss-grid, .bs-works-grid, .bs-blog-grid{grid-template-columns:1fr;}
  .bsh-card-event{padding:22px 22px;}
  .bsh-ctas{flex-direction:column;}
  .bsh-ctas .btn{width:100%;}
  .cms-tag{font-size:11px;padding:5px 12px;}
}

/* ============================================================
   sample-site-cms.html — Plan B らしさを一発で伝える要素群
============================================================ */

/* ===== CMS Overview Strip (Hero直下) ===== */
.bs-cms-strip{
  background:linear-gradient(180deg, var(--c-soft) 0%, #fff 100%);
  padding:48px 0 56px;
  border-bottom:1px solid var(--c-line);
}
.bcs-head{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:24px;flex-wrap:wrap;margin-bottom:28px;
}
.bcs-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14px;font-weight:700;color:var(--c-primary);
  letter-spacing:0.05em;
}
.bcs-eyebrow strong{color:var(--c-accent-2);font-weight:800;}
.bcs-ico{
  display:inline-grid;place-items:center;
  width:26px;height:26px;border-radius:50%;
  background:var(--c-accent);color:#fff;
  font-size:14px;font-weight:700;line-height:1;
}
.bcs-sub{font-size:13px;color:var(--c-text-2);line-height:1.85;}
.bcs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.bcs-mini{
  position:relative;background:#fff;
  border:1px solid var(--c-line);border-top:3px solid var(--c-accent);
  border-radius:var(--radius);
  padding:20px 22px 22px;
  display:flex;flex-direction:column;gap:6px;
  transition:all var(--tr);
}
.bcs-mini:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm);border-color:var(--c-accent);border-top-color:var(--c-accent);}
.bcs-cap{
  font-family:var(--f-en);font-size:11px;font-weight:700;
  letter-spacing:0.18em;color:var(--c-muted);
}
.bcs-mini strong{
  font-size:17px;font-weight:800;color:var(--c-primary);
  letter-spacing:0.04em;line-height:1.4;
}
.bcs-meta{font-size:12px;color:var(--c-text-2);line-height:1.6;}
.bcs-pill{
  margin-top:8px;align-self:flex-start;
  padding:4px 10px;border-radius:12px;
  background:rgba(232,168,70,0.18);color:var(--c-accent-2);
  font-size:11px;font-weight:700;letter-spacing:0.05em;
}

/* ===== Event card CMS note (hero right) ===== */
.bshc-cms-note{
  margin-top:18px;padding-top:14px;
  border-top:1px dashed var(--c-line);
  font-size:11px;color:var(--c-accent-2);
  letter-spacing:0.04em;line-height:1.65;
  font-weight:600;
}

/* ===== CMS Status Pill (in section heads) ===== */
.cms-status{
  display:inline-block;margin-left:10px;
  padding:3px 10px;border-radius:3px;
  background:var(--c-accent);color:#fff;
  font-family:var(--f-en);font-size:10px;font-weight:700;letter-spacing:0.18em;
  vertical-align:middle;
  position:relative;top:-2px;
}

/* ===== Card CMS corner mark (WORKS / BLOG cards) ===== */
.card-cms-mark{
  position:absolute;top:10px;right:10px;z-index:2;
  display:grid;place-items:center;
  width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,0.92);color:var(--c-accent-2);
  font-size:13px;font-weight:700;line-height:1;
  border:1px solid rgba(232,168,70,0.5);
  backdrop-filter:blur(4px);
  box-shadow:0 2px 8px rgba(0,0,0,0.15);
  cursor:help;
}
.bsw-thumb, .bsb-thumb { position:relative; }

/* ===== Responsive ===== */
@media (max-width:1024px){
  .bcs-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:700px){
  .bs-cms-strip{padding:36px 0 40px;}
  .bcs-grid{grid-template-columns:1fr;}
  .bcs-head{flex-direction:column;align-items:flex-start;gap:8px;}
  .cms-status{margin-left:0;margin-top:4px;display:inline-block;}
}

/* ============================================================
   Dashboard Preview (sample-site-cms.html)
============================================================ */
.bs-dashboard{background:var(--c-soft);}

.dash-frame{
  background:#fff;border-radius:14px;
  border:1px solid var(--c-line-2);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(15,30,58,0.18);
}

/* Title bar */
.dash-titlebar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  background:linear-gradient(180deg, #fafbfc 0%, #f1f3f7 100%);
  border-bottom:1px solid var(--c-line);gap:16px;
}
.dash-bar-left{display:inline-flex;align-items:center;gap:12px;}
.dash-mark{
  display:inline-grid;place-items:center;
  width:28px;height:28px;border-radius:6px;
  background:linear-gradient(135deg, var(--c-primary), var(--c-dark));
  color:var(--c-accent);
  font-size:11px;font-weight:700;letter-spacing:0.05em;
}
.dash-bar-text{
  font-size:12px;color:var(--c-text-2);font-weight:600;letter-spacing:0.05em;
}
.dash-user-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:20px;
  background:#fff;border:1px solid var(--c-line);
  font-size:11px;color:var(--c-text-2);font-weight:600;
}
.dash-user-avatar{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg, var(--c-accent), var(--c-accent-2));
}

/* Body */
.dash-body{
  display:grid;grid-template-columns:240px 1fr;
  min-height:520px;
}

/* Sidebar */
.dash-sidebar{
  background:#fafbfc;
  border-right:1px solid var(--c-line);
  padding:24px 0;
}
.dsbar-cap{
  display:block;padding:0 24px;
  font-family:var(--f-en);font-size:10px;font-weight:700;
  letter-spacing:0.22em;color:var(--c-muted);
  margin-bottom:8px;
}
.dash-sidebar ul{margin-bottom:24px;list-style:none;padding:0;}
.dash-sidebar ul:last-child{margin-bottom:0;}
.dash-sidebar li{
  padding:11px 24px;
  font-size:13.5px;color:var(--c-text-2);
  cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  transition:all 0.2s;
  border-left:3px solid transparent;
}
.dash-sidebar li:hover{background:rgba(15,30,58,0.04);color:var(--c-primary);}
.dash-sidebar li.active{
  background:rgba(232,168,70,0.10);
  color:var(--c-primary);font-weight:700;
  border-left-color:var(--c-accent);
}
.ds-count{
  font-family:var(--f-en);font-size:11px;font-weight:600;
  color:var(--c-muted);background:#e5e7eb;
  padding:2px 8px;border-radius:10px;line-height:1.4;
}
.dash-sidebar li.active .ds-count{
  background:var(--c-accent);color:#fff;
}
.ds-count.alt{
  background:rgba(232,168,70,0.18);color:var(--c-accent-2);
}

/* Main */
.dash-main{padding:28px 32px;background:#fff;}
.dash-main-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;padding-bottom:20px;margin-bottom:20px;
  border-bottom:1px solid var(--c-line);
}
.dmh-text h3{
  font-size:20px;font-weight:700;color:var(--c-primary);
  margin-bottom:6px;letter-spacing:0.03em;
}
.dmh-text h3 small{
  font-size:12px;color:var(--c-muted);font-weight:500;
  margin-left:10px;font-family:var(--f-en);
}
.dmh-text p{font-size:12.5px;color:var(--c-text-2);}
.dash-add{
  padding:10px 18px;
  background:var(--c-accent);color:#fff;
  border-radius:6px;
  font-size:13px;font-weight:700;letter-spacing:0.05em;
  cursor:pointer;transition:all 0.2s;white-space:nowrap;
  border:none;font-family:inherit;
}
.dash-add:hover{background:var(--c-accent-2);transform:translateY(-1px);}

/* Row list */
.dash-list{display:flex;flex-direction:column;gap:6px;}
.dash-row{
  display:grid;
  grid-template-columns:1fr 90px 100px 70px;
  gap:18px;align-items:center;
  padding:14px 18px;
  border:1px solid var(--c-line);border-radius:6px;
  background:#fff;
  transition:all 0.2s;
}
.dash-row:hover{
  border-color:var(--c-accent);
  background:rgba(232,168,70,0.04);
}
.dash-cell-title{
  display:flex;flex-direction:column;gap:5px;min-width:0;
}
.dash-title-text{
  font-size:13.5px;color:var(--c-primary);font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.dash-cat{
  align-self:flex-start;
  padding:2px 9px;border-radius:8px;
  background:rgba(232,168,70,0.15);color:var(--c-accent-2);
  font-size:10px;font-weight:700;letter-spacing:0.05em;
}
.dash-status{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:12px;
  font-size:11px;font-weight:700;letter-spacing:0.05em;
  white-space:nowrap;
}
.dash-status::before{
  content:'';width:6px;height:6px;border-radius:50%;
}
.dash-status.published{
  background:rgba(16,185,129,0.13);color:#0e6b51;
}
.dash-status.published::before{background:#10b981;}
.dash-status.draft{
  background:rgba(107,114,128,0.13);color:#4b5563;
}
.dash-status.draft::before{background:#9ca3af;}
.dash-date{
  font-family:var(--f-en);font-size:12px;color:var(--c-muted);letter-spacing:0.03em;
}
.dash-edit{
  padding:6px 12px;
  background:#fff;color:var(--c-primary);
  border:1px solid var(--c-line-2);border-radius:4px;
  font-size:12px;font-weight:600;letter-spacing:0.05em;
  cursor:pointer;transition:all 0.2s;font-family:inherit;
}
.dash-edit:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary);}

.dash-note{
  margin-top:18px;font-size:11.5px;color:var(--c-muted);
  text-align:center;letter-spacing:0.02em;
}

/* Responsive */
@media (max-width:900px){
  .dash-body{grid-template-columns:1fr;min-height:auto;}
  .dash-sidebar{
    border-right:none;border-bottom:1px solid var(--c-line);
    padding:18px 0 14px;
  }
  .dash-sidebar ul{
    display:flex;flex-wrap:wrap;gap:6px;
    padding:0 18px;margin-bottom:14px;
  }
  .dash-sidebar li{
    padding:6px 12px;border-left:none;border-radius:4px;
    background:#fff;border:1px solid var(--c-line);
  }
  .dash-sidebar li.active{
    background:var(--c-primary);color:#fff;border-color:var(--c-primary);
  }
  .dash-sidebar li.active .ds-count{background:var(--c-accent);}
  .dsbar-cap{padding:0 18px;}
  .dash-main{padding:22px 20px;}
  .dash-row{
    grid-template-columns:1fr;gap:10px;padding:14px 16px;
  }
  .dash-status, .dash-date, .dash-edit{justify-self:start;}
  .dash-titlebar{padding:10px 14px;}
  .dash-bar-text{display:none;}
  .dash-main-head{flex-direction:column;align-items:stretch;}
  .dash-add{align-self:flex-start;}
}

/* ============================================================
   Plan card refinements (Plan B 自社更新プラン)
============================================================ */
.plan-c-title .plan-c-sub{
  display:inline-block;margin-left:8px;
  font-size:13px;font-weight:500;
  color:var(--c-muted);letter-spacing:0.04em;
  vertical-align:baseline;
}

.plan-c-mini-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  margin:14px 0 18px;
}
.pcmt{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:14px;
  background:rgba(232,168,70,0.13);
  color:var(--c-accent-2);
  font-size:11px;font-weight:700;letter-spacing:0.04em;
  border:1px solid rgba(232,168,70,0.25);
}
.pcmt-ico{
  display:inline-grid;place-items:center;
  width:14px;height:14px;border-radius:50%;
  background:var(--c-accent);color:#fff;
  font-size:9px;font-weight:700;line-height:1;
}

@media (max-width:700px){
  .plan-c-title .plan-c-sub{
    display:block;margin-left:0;margin-top:4px;font-size:12px;
  }
  .plan-c-mini-tags{margin:12px 0 16px;gap:5px;}
  .pcmt{font-size:10.5px;padding:3px 8px;}
}

/* ============================================================
   Dashboard interactive switcher (sample-site-cms.html)
============================================================ */
.dash-panel[hidden]{display:none;}
.dash-sidebar li[data-tab]{
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.dash-sidebar li[data-tab]:focus-visible{
  outline:2px solid var(--c-accent);
  outline-offset:-2px;
}

/* ============================================================
   Thanks page
============================================================ */
.thanks-page{
  min-height:calc(100vh - 80px);
  display:flex;align-items:center;justify-content:center;
  padding:120px 0 80px;
  background:var(--c-soft);
}
.thanks-inner{
  max-width:640px;margin:0 auto;
  text-align:center;
}
.thanks-icon{
  width:72px;height:72px;margin:0 auto 24px;
  display:grid;place-items:center;
  border-radius:50%;
  background:var(--c-success);color:#fff;
  font-size:32px;font-weight:700;line-height:1;
}
.thanks-title{
  font-size:clamp(22px,3.5vw,30px);
  font-weight:800;color:var(--c-primary);
  margin-bottom:16px;
}
.thanks-lead{
  font-size:15px;line-height:1.9;
  color:var(--c-text-2);margin-bottom:40px;
}
.thanks-notice{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-lg);padding:32px;
  margin-bottom:40px;text-align:left;
}
.thanks-notice h2{
  font-size:15px;font-weight:700;
  color:var(--c-primary);margin-bottom:12px;
}
.thanks-notice > p{
  font-size:13px;line-height:1.9;
  color:var(--c-text-2);margin-bottom:20px;
}
.thanks-contact{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.thanks-contact-item{
  padding:20px;background:var(--c-soft);
  border-radius:var(--radius);
  border-left:3px solid var(--c-accent);
}
.thanks-contact-item h3{
  font-size:11px;color:var(--c-muted);
  letter-spacing:0.15em;font-weight:600;margin-bottom:8px;
}
.thanks-contact-item a{
  display:block;font-family:var(--f-en);
  font-size:18px;font-weight:700;color:var(--c-primary);
  word-break:break-all;
}
.thanks-contact-item span{
  display:block;font-size:12px;color:var(--c-muted);margin-top:4px;
}
.thanks-btns{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
}

/* Form error message */
.form-error{
  margin-top:12px;font-size:13px;font-weight:600;
  color:#dc2626;
}

@media(max-width:700px){
  .thanks-page{padding:100px 0 60px;}
  .thanks-notice{padding:24px;}
  .thanks-contact{grid-template-columns:1fr;}
  .thanks-btns{flex-direction:column;}
  .thanks-btns .btn{width:100%;}
}

/* ===== Doc / Legal page (privacy, terms) ===== */
.doc-page{
  padding:140px 0 80px;background:var(--c-soft);
}
.doc-inner{max-width:880px;}
.doc-head{
  text-align:center;padding-bottom:36px;margin-bottom:36px;
  border-bottom:1px solid var(--c-line);
}
.doc-label{
  display:inline-block;font-family:var(--f-en);font-size:12px;
  font-weight:700;letter-spacing:0.25em;color:var(--c-accent);
  margin-bottom:14px;
}
.doc-head h1{
  font-size:clamp(26px,3.5vw,34px);font-weight:800;color:var(--c-primary);
  margin-bottom:18px;letter-spacing:0.02em;
}
.doc-intro{
  font-size:14.5px;line-height:2;color:var(--c-text-2);
  max-width:680px;margin:0 auto;
}

.doc-section{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:32px 40px;margin-bottom:18px;
}
.doc-section h2{
  font-size:16px;font-weight:700;color:var(--c-primary);
  margin-bottom:14px;padding-left:14px;position:relative;
  letter-spacing:0.02em;
}
.doc-section h2::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:4px;height:18px;background:var(--c-accent);border-radius:2px;
}
.doc-section p{
  font-size:14px;line-height:2;color:var(--c-text-2);margin-bottom:10px;
}
.doc-section p:last-child{margin-bottom:0;}
.doc-section ul{
  margin-top:8px;padding-left:0;list-style:none;
}
.doc-section ul li{
  position:relative;padding-left:20px;
  font-size:13.5px;line-height:1.95;color:var(--c-text-2);
  margin-bottom:4px;
}
.doc-section ul li::before{
  content:'・';position:absolute;left:0;top:0;color:var(--c-accent);font-weight:700;
}
.doc-section a{color:var(--c-accent);font-weight:600;}
.doc-section a:hover{color:var(--c-accent-2);text-decoration:underline;}

.doc-contact{
  background:var(--c-soft);border-left:3px solid var(--c-accent);
  padding:20px 24px;border-radius:var(--radius);
}
.doc-contact p{font-size:14px;line-height:2;margin-bottom:4px;color:var(--c-text);}
.doc-contact p:last-child{margin-bottom:0;}
.doc-contact strong{color:var(--c-primary);font-weight:700;}

/* Legal page table */
.doc-table{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;
}
.doc-row{
  display:grid;grid-template-columns:200px 1fr;
  border-bottom:1px solid var(--c-line);
}
.doc-row:last-child{border-bottom:none;}
.doc-row dt{
  padding:20px 24px;background:var(--c-soft);
  font-size:13.5px;font-weight:700;color:var(--c-primary);
  letter-spacing:0.02em;line-height:1.7;
  border-right:1px solid var(--c-line);
}
.doc-row dd{
  padding:20px 28px;font-size:14px;line-height:2;
  color:var(--c-text-2);
}
.doc-row dd ul{
  margin:8px 0 0;padding-left:0;list-style:none;
}
.doc-row dd ul li{
  position:relative;padding-left:18px;font-size:13.5px;line-height:1.95;
  margin-bottom:4px;
}
.doc-row dd ul li::before{
  content:'・';position:absolute;left:0;top:0;color:var(--c-accent);font-weight:700;
}
.doc-row dd small{
  display:block;margin-top:6px;font-size:12px;color:var(--c-muted);line-height:1.7;
}
.doc-row dd a{color:var(--c-accent);font-weight:600;}

.doc-revised{
  text-align:right;font-size:12.5px;color:var(--c-muted);
  margin-top:24px;
}
.doc-back{
  display:flex;justify-content:center;margin-top:48px;
}

/* Footer company info block */
.foot-company{
  margin-top:18px;padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.foot-company p{
  font-size:12px;line-height:1.9;color:#94a3b8;margin-bottom:2px;
}

@media(max-width:700px){
  .doc-page{padding:100px 0 60px;}
  .doc-section{padding:22px 22px;}
  .doc-row{grid-template-columns:1fr;}
  .doc-row dt{
    padding:14px 18px;border-right:none;border-bottom:1px solid var(--c-line);
  }
  .doc-row dd{padding:16px 18px;}
}

/* ============================================================
   Sample-site-1 color override (cleaning / estate service)
============================================================ */
.demo-site{
  --c-primary:#1b5e4b;
  --c-dark:#0e3a2e;
  --c-dark-2:#092a20;
  --c-accent:#3bb78f;
  --c-accent-2:#2a9a74;
}
.demo-site .dh-decor{
  background-image:
    radial-gradient(circle at 15% 25%, rgba(59,183,143,0.18) 0%, transparent 40%),
    radial-gradient(circle at 85% 75%, rgba(59,183,143,0.10) 0%, transparent 45%);
}
.demo-site .dh-chip{
  background:rgba(59,183,143,0.15);border-color:rgba(59,183,143,0.3);
}
.demo-site .case-cta::before{
  background-image:radial-gradient(circle at 80% 30%, rgba(59,183,143,0.18) 0%, transparent 45%);
}
.demo-site .dp-card.featured{
  background:linear-gradient(180deg,#fff,#f0faf5);
}
.demo-site .demo-reasons{background:#f0faf5;}
.demo-site .demo-cases{background:#f0faf5;}
.demo-site .demo-faq{background:#f0faf5;}
.demo-site .dp-note{background:#f0faf5;}
.demo-site .rel-tag{background:rgba(59,183,143,0.15);}
.demo-site .case-footer{background:#122b23;}
.demo-site .cf-brand .case-brand-mark{
  background:linear-gradient(135deg, var(--c-accent), var(--c-accent-2));color:#fff;
}
.demo-site .btn-primary{
  background:var(--c-accent);box-shadow:0 4px 14px rgba(59,183,143,0.3);
}
.demo-site .btn-primary:hover{
  background:var(--c-accent-2);box-shadow:0 8px 24px rgba(59,183,143,0.4);
}
.demo-site .sample-banner{background:var(--c-dark);}
.demo-site .sb-text strong{color:var(--c-accent);}
.demo-site .sb-link{color:var(--c-accent);}
.demo-site .return-banner{border-top-color:var(--c-accent);}
