/* くらしの手続き相談窓口 - 協業ブランディングサイト
   トーン：白基調 / 重厚・エレガント
*/
:root{
  --bg:#ffffff;
  --ink:#0b1220;
  --muted:#4b5563;
  --line:#e5e7eb;
  --soft:#f6f7fb;
  --accent:#111827;
  --accent2:#0f172a;
  --gold:#b08d57;
  --shadow: 0 18px 40px rgba(17,24,39,.08);
  --shadow2: 0 10px 24px rgba(17,24,39,.10);
  --radius: 22px;
  --radius2: 28px;
  --max: 1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif;
  color:var(--ink);
  background: radial-gradient(1000px 600px at 60% -10%, rgba(176,141,87,.10), transparent 55%),
              radial-gradient(900px 600px at 0% 10%, rgba(15,23,42,.06), transparent 60%),
              var(--bg);
  line-height:1.75;
}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
p{margin:0 0 1em}
small{color:var(--muted)}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.section{padding:64px 0}
.section.tight{padding:46px 0}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--muted);letter-spacing:.08em;font-size:12px;text-transform:uppercase;
  text-shadow:
    -0.75px -0.75px 0 #fff,
     0.75px -0.75px 0 #fff,
    -0.75px  0.75px 0 #fff,
     0.75px  0.75px 0 #fff;
}
.kicker:before{
  content:"";width:28px;height:1px;background:linear-gradient(90deg,var(--gold), transparent);
}
.h2{
  font-family:"Noto Serif JP", serif;
  font-weight:700;
  font-size:clamp(22px, 3.2vw, 34px);
  line-height:1.25;
  margin:12px 0 18px;
}
.h3{
  font-family:"Noto Serif JP", serif;
  font-weight:700;
  font-size:clamp(18px, 2.2vw, 24px);
  line-height:1.35;
  margin:0 0 12px;
}
.lead{font-size:clamp(15px, 1.6vw, 18px); color:var(--muted)}
.card{
  background:rgba(255,255,255,.88);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card.pad{padding:22px}
.grid{
  display:grid;
  gap:18px;
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 18px;border-radius:999px;border:1px solid var(--accent);
  background:linear-gradient(180deg, var(--accent), var(--accent2));
  color:#fff;font-weight:700; letter-spacing:.02em;
  box-shadow:var(--shadow2);
  transition:.2s transform, .2s box-shadow, .2s opacity;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px); box-shadow:0 16px 34px rgba(17,24,39,.18)}
.btn.secondary{
  background:#fff;color:var(--accent);
  border:1px solid rgba(17,24,39,.22);
}
.btn.secondary:hover{box-shadow:0 16px 34px rgba(17,24,39,.10)}
.btn.ghost{
  background:transparent;color:var(--accent);
  border:1px solid rgba(17,24,39,.18);
  box-shadow:none;
}
.badge{
  display:inline-flex;gap:8px;align-items:center;
  font-size:12px;color:var(--muted);
  padding:10px 12px;border-radius:999px;
  border:1px solid var(--line); background:rgba(255,255,255,.72);
}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.hr{
  height:1px;background:linear-gradient(90deg, transparent, rgba(17,24,39,.18), transparent);
  margin:18px 0;
}
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.74);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(229,231,235,.7);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto;display:block}
.brand-name{font-family:"Noto Serif JP", serif;font-weight:800;letter-spacing:.06em;font-size:16px;line-height:1;color:var(--ink);position:relative}
.brand-name:after{content:"";position:absolute;left:0;bottom:-6px;width:60%;height:2px;background:linear-gradient(90deg,var(--gold), transparent);opacity:0;transform:translateY(2px);transition:.25s}

.nav{display:flex;gap:14px;align-items:center}
.nav a{font-size:13px;color:var(--muted);padding:10px 10px;border-radius:999px}
.nav a:hover{background:rgba(17,24,39,.04);color:var(--ink)}
.nav .cta{display:none}
.mobile-toggle{
  display:none; border:1px solid var(--line); background:#fff;
  border-radius:14px; padding:10px 12px; box-shadow:0 10px 22px rgba(17,24,39,.06);
}
.mobile-menu{
  display:none; padding:10px 0 16px;
}
.mobile-menu a{display:block;padding:12px 14px;border-radius:14px;color:var(--muted)}
.mobile-menu a:hover{background:rgba(17,24,39,.04);color:var(--ink)}
.hero{
  padding:46px 0 20px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  align-items:stretch;
}
.hero-copy{
  position:relative;
  padding:34px 30px;
  border-radius:var(--radius2);
  background:
    url('../img/hero.png') center/cover no-repeat,
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.84)),
    radial-gradient(700px 380px at 10% 0%, rgba(176,141,87,.18), transparent 55%),
    radial-gradient(700px 380px at 100% 10%, rgba(15,23,42,.10), transparent 60%);
  background-blend-mode: multiply, normal, normal, normal;
  border:1px solid rgba(229,231,235,.9);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-copy:after{
  content:""; position:absolute; inset:-2px;
  background:
    linear-gradient(140deg, rgba(176,141,87,.24), transparent 42%),
    linear-gradient(320deg, rgba(17,24,39,.12), transparent 46%);
  opacity:.45; pointer-events:none;
}
.hero-title{
  position:relative;
  font-family:"Noto Serif JP", serif;
  font-weight:800;
  font-size:clamp(26px, 4.2vw, 44px);
  line-height:1.18;
  margin:0 0 14px;
  text-shadow:
    -1px -1px 0 #fff,
     1px -1px 0 #fff,
    -1px  1px 0 #fff,
     1px  1px 0 #fff;
}
.hero-sub{position:relative;color:var(--muted);font-size:clamp(14px, 1.6vw, 18px);margin:0 0 16px;
  text-shadow:
    -0.75px -0.75px 0 #fff,
     0.75px -0.75px 0 #fff,
    -0.75px  0.75px 0 #fff,
     0.75px  0.75px 0 #fff;
}
.hero-actions{position:relative;display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:18px}
.hero-points{position:relative;display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:10px;margin-top:18px}
.point{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  padding:12px 12px;
  box-shadow:0 12px 26px rgba(17,24,39,.06);
}
.point b{display:block;font-size:13px}
.point span{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.hero-side{
  display:grid; gap:12px;
}
.quick{
  padding:18px;
}
.quick .row{display:flex;gap:10px;align-items:center}
.icon{
  width:38px;height:38px;border-radius:14px;
  background:linear-gradient(180deg, rgba(17,24,39,.96), rgba(15,23,42,.96));
  display:grid;place-items:center;color:#fff;
  flex:0 0 auto;
}
.quick h4{margin:0 0 6px;font-size:14px;font-weight:800}
.quick p{margin:0;color:var(--muted);font-size:13px}
.marquee{
  overflow:hidden;
  border-top:1px solid rgba(229,231,235,.8);
  border-bottom:1px solid rgba(229,231,235,.8);
  background:rgba(255,255,255,.62);
}
.marquee-track{
  display:flex;gap:34px;align-items:center;
  padding:14px 0;
  animation: scroll 18s linear infinite;
  white-space:nowrap;
}
.marquee span{color:var(--muted);font-size:12px;letter-spacing:.08em}
.marquee b{color:var(--ink)}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.pain{
  padding:24px;
}
.pain ul{margin:0;padding-left:18px;color:var(--muted)}
.pain li{margin:8px 0}
.solution{
  padding:24px;
}
.steps{counter-reset:step;display:grid;gap:12px;margin-top:12px}
.step{
  display:flex;gap:12px;align-items:center;
  padding:14px;border-radius:18px;background:rgba(246,247,251,.85);
  border:1px solid rgba(229,231,235,.95);
}
.step:before{
  counter-increment:step; content:counter(step);
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  color:#fff; font-weight:800;
  background:linear-gradient(180deg,var(--accent), var(--accent2));
  flex:0 0 auto;
}
.offices{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:stretch;
}
.office{
  display:grid;
  grid-template-columns: 160px 1fr;
  gap:16px;
  padding:22px;
}
.office figure{margin:0}
.office .photo{
  width:160px;height:200px;border-radius:22px;
  background:linear-gradient(180deg, rgba(17,24,39,.06), rgba(17,24,39,.02));
  border:1px solid rgba(229,231,235,.95);
  display:grid;place-items:end center;
  overflow:hidden;
}
.office .photo img{width:100%;height:auto;transform:translateY(18px)}
.office .meta small{display:block}
.office .meta a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.office .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag{
  font-size:12px;color:var(--muted);
  border:1px solid var(--line);
  padding:8px 10px;border-radius:999px;background:#fff;
}
.services{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:18px;
}
.service{
  padding:22px;
  position:relative;
}
.service .num{
  position:absolute;top:16px;right:16px;
  width:40px;height:40px;border-radius:16px;
  display:grid;place-items:center;
  color:#fff;font-weight:900;
  background:linear-gradient(180deg,var(--accent), var(--accent2));
}
.service ul{margin:10px 0 0;padding-left:18px;color:var(--muted);font-size:13px}
.service li{margin:6px 0}
.faq{
  max-width:920px;
}
.accordion{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.acc-item + .acc-item{border-top:1px solid var(--line)}
.acc-btn{
  width:100%;text-align:left; padding:16px 18px;
  display:flex;justify-content:space-between;gap:12px; align-items:center;
  background:#fff;border:0; cursor:pointer;
}
.acc-btn b{font-size:14px}
.acc-btn span{color:var(--muted);font-size:12px}
.acc-panel{display:none;padding:0 18px 16px;color:var(--muted);font-size:13px}
.acc-item[aria-expanded="true"] .acc-panel{display:block}
.acc-item[aria-expanded="true"] .chev{transform:rotate(180deg)}
.chev{transition:.2s transform;color:var(--muted)}
.cta{
  position:relative;
  padding:28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.82)),
    radial-gradient(900px 380px at 20% 0%, rgba(176,141,87,.22), transparent 55%),
    radial-gradient(900px 380px at 80% 10%, rgba(15,23,42,.10), transparent 60%);
  border:1px solid rgba(229,231,235,.95);
}
.form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:16px;
}
.form .full{grid-column:1/-1}
label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
input, select, textarea{
  width:100%; padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(229,231,235,1);
  background:#fff;
  font-size:14px;
}
textarea{min-height:120px;resize:vertical}
.form-note{font-size:12px;color:var(--muted);margin-top:10px}
.footer{
  border-top:1px solid rgba(229,231,235,.9);
  background:rgba(255,255,255,.64);
  padding:28px 0;
}
.footer-grid{
  display:grid;grid-template-columns: 1.2fr .8fr;gap:18px;align-items:start;
}
.footer a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.bottom-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  background:rgba(255,255,255,.76);
  backdrop-filter: blur(10px);
  border-top:1px solid rgba(229,231,235,.9);
}
.bottom-bar .inner{
  max-width:var(--max);
  margin:0 auto;
  padding:10px 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.bottom-bar a{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 14px;border-radius:16px;
  font-weight:900;
  box-shadow:0 14px 30px rgba(17,24,39,.12);
}
.bottom-bar a.form{
  background:linear-gradient(180deg,var(--accent), var(--accent2));
  color:#fff;
}
.bottom-bar a.line{
  background:#06C755;
  color:#fff;
  border:1px solid rgba(0,0,0,.08);
}
@media (max-width: 520px){
  .bottom-bar .inner{grid-template-columns:1fr}
  }
.modal-backdrop{
  position:fixed;inset:0;background:rgba(11,18,32,.52);
  display:none;place-items:center;z-index:80;
  padding:18px;
}
.modal{
  width:min(780px, 100%);
  background:#fff;border-radius:24px;
  border:1px solid rgba(229,231,235,.95);
  box-shadow:0 24px 70px rgba(0,0,0,.22);
  overflow:hidden;
}
.modal header{
  padding:18px 18px 0;
  display:flex;justify-content:space-between;gap:12px;align-items:center;
}
.modal header b{font-family:"Noto Serif JP", serif;font-size:18px}
.modal .body{padding:10px 18px 18px;color:var(--muted);font-size:13px}
.modal .actions{padding:0 18px 18px;display:flex;gap:10px;flex-wrap:wrap}
.xbtn{
  width:40px;height:40px;border-radius:14px;border:1px solid var(--line);
  background:#fff;cursor:pointer;
}
.reveal{opacity:0; transform:translateY(10px); transition:.7s opacity, .7s transform}
.reveal.in{opacity:1; transform:none}
@media (max-width: 960px){
  .hero-grid{grid-template-columns:1fr}
  .services{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .offices{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .nav{display:none}
  .mobile-toggle{display:inline-flex}
  .mobile-menu{display:block}
  .hero-points{grid-template-columns:1fr}
}

.reveal.slide-left{transform:translateX(-18px);}
.reveal.slide-right{transform:translateX(18px);}
.reveal.in.slide-left,.reveal.in.slide-right{transform:none;}

.card{transition:.18s transform,.18s box-shadow}
.card:hover{transform:translateY(-2px);}
@media (prefers-reduced-motion: reduce){.card{transition:none}.card:hover{transform:none}.marquee-track{animation:none}.reveal{transition:none}}

.checkbox-row{display:flex;align-items:center;gap:10px;justify-content:flex-start}
.checkbox-row input{width:18px;height:18px;margin-top:3px}

/* 代表写真の見え方（人物像が丁度良くなるよう調整） */
.photo img{width:100%;height:100%;object-fit:contain}
img.rep.daisei{transform:scale(1.10) translateY(18px);}
img.rep.hanawa{transform:scale(1.05) translateY(22px);}

@keyframes floaty{0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}
.hero-side .quick{animation:none}

@media (prefers-reduced-motion: reduce){.hero-side .quick{animation:none}}


/* footer google */
.footer-google{margin-top:24px}
.footer-google-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:10px}
.map-embed{border-radius:16px;overflow:hidden;border:1px solid var(--line);margin-top:8px}
.mini-actions{margin-top:10px}
.muted{color:var(--muted)}
@media (max-width: 900px){
  .footer-google-grid{grid-template-columns:1fr}
}

/* 追従フッターCTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:999;display:flex;gap:8px;padding:10px;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.2) blur(8px);border-top:1px solid var(--line)}
.sticky-cta .cta-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:12px 10px;text-decoration:none;font-weight:800}
.sticky-cta .cta-ic{font-size:16px;line-height:1}
.sticky-cta .cta-txt{font-size:13px;line-height:1}
.sticky-cta .cta-btn.phone{background:#111;color:#fff}
.sticky-cta .cta-btn.line{background:#06c755;color:#fff}
.sticky-cta .cta-btn.form{background:var(--gold);color:#111}
@media (min-width: 901px){
  .sticky-cta{max-width:980px;margin:0 auto;border-left:1px solid var(--line);border-right:1px solid var(--line);border-top-left-radius:16px;border-top-right-radius:16px}
}


/* コラボの強み */
.collab-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:12px}
.collab-ic{font-size:26px;margin-bottom:8px}
@media (max-width: 900px){.collab-grid{grid-template-columns:1fr}}


/* フォーム進捗 */
.form-progress{padding:14px;border-radius:18px;border:1px solid var(--line);background:rgba(0,0,0,.02)}
.progress-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.progress-bar{height:10px;border-radius:999px;background:rgba(0,0,0,.08);overflow:hidden;margin-top:8px}
.progress-bar span{display:block;height:100%;width:0%;background:var(--gold);border-radius:999px;transition:width .2s ease}


/* 事例 */
.case-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:12px}
.case .lead{margin:6px 0}
@media (max-width: 900px){.case-grid{grid-template-columns:1fr}}


/* 3分診断 */
.hero-subpage .hero-grid{grid-template-columns:1.2fr .8fr}
.diag-list{display:grid;gap:10px;margin-top:14px}
.diag-list label{display:flex;gap:10px;align-items:center;font-size:14px;color:var(--ink);padding:10px 12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.9)}
.diag-list input{margin-top:2px;flex:0 0 auto}

.brand-wrap{display:flex;align-items:center;gap:12px}
.brand-name:hover:after,.brand-name:focus-visible:after{opacity:.9;transform:none}
.brand-name{white-space:nowrap}

/* 追従フッターCTA */
.floating-cta{
  position:fixed; left:0; right:0; bottom:0;
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:10px;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  border-top:1px solid var(--line);
  z-index: 50;
}
.floating-btn{
  display:flex; align-items:center; justify-content:center;
  gap:8px;
  height:56px; /* 3ボタンの高さを統一 */
  padding:0 12px;
  border-radius:999px;
  font-weight:800;
  box-shadow: var(--shadow2);
  border:1px solid rgba(0,0,0,.06);
}
.floating-btn .txt{white-space:nowrap;font-size:13px;line-height:1}
@media (max-width: 420px){
  .floating-btn .txt{font-size:12px}
}
.floating-btn .ico{font-size:16px}
.floating-btn .ico svg{width:18px;height:18px;display:block;fill:currentColor}
.floating-btn .ico{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.floating-btn.tel{background:#0b1220;color:#fff}
.floating-btn.line{background:#17c964;color:#fff}
.floating-btn.form{background:var(--gold);color:#fff}
@media (min-width: 920px){
  .floating-cta{max-width:820px; margin:0 auto 14px; left:50%; right:auto; transform:translateX(-50%); border:1px solid var(--line); border-radius:999px}
}

.footer-google{margin-top:28px}
.footer-google-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.map-embed{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff}
.mini-actions{margin-top:10px}
@media (max-width: 860px){
  .footer-google-grid{grid-template-columns:1fr}
}

/* Hero visual slider */
.hero-visual{padding:0;position:relative;min-height:260px}
.hero-slider{position:relative;height:260px;border-radius:var(--radius);overflow:hidden}
.hero-slide{
  position:absolute; inset:0;
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap:10px;
  padding:22px 22px;
  opacity:0; transform:scale(1.02);
  transition:opacity .6s ease, transform .8s ease;
  background:
    radial-gradient(500px 280px at 20% 20%, rgba(176,141,87,.18), transparent 60%),
    linear-gradient(135deg, rgba(15,23,42,.08), rgba(255,255,255,.0)),
    url('../img/hero-bg.svg');
  background-size: cover;
}
.hero-slide.is-active{opacity:1;transform:none}
.hero-slide h3{margin:0;font-family:"Noto Serif JP", serif;font-size:22px;letter-spacing:.04em}
.hero-slide p{margin:.35em 0 0;color:var(--muted);font-size:14px;line-height:1.7}
.hero-slide .pillars{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.hero-slide .pillars span{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.82);border:1px solid var(--line);font-size:12px;font-weight:700}
.hero-slide .reps{display:flex;gap:10px;justify-content:flex-end;align-items:end}
.hero-slide .rep{display:flex;flex-direction:column;align-items:center;gap:6px}
.hero-slide .rep img{width:108px;height:108px;border-radius:20px;object-fit:cover;border:1px solid var(--line);box-shadow:var(--shadow2);background:#fff}
.hero-slide .rep small{font-size:11px;color:var(--muted)}
.hero-dots{position:absolute;left:16px;bottom:14px;display:flex;gap:8px;z-index:2}
.hero-dots button{width:10px;height:10px;border-radius:999px;border:1px solid rgba(0,0,0,.25);background:rgba(255,255,255,.65);cursor:pointer}
.hero-dots button[aria-current="true"]{background:var(--gold);border-color:transparent}
@media (max-width: 1020px){
  .hero-slide{grid-template-columns:1fr}
  .hero-slide .reps{justify-content:flex-start}
  .hero-visual,.hero-slider{min-height:300px;height:300px}
}

/* Card rhythm / equal heights */
.services .card, .cases-grid .card, .collab-grid .card{display:flex;flex-direction:column}
.services .card .btn, .cases-grid .card .btn{margin-top:auto}

.h1,.h2,.h3{line-height:1.25}
.h2{margin:0 0 10px}

body{padding-bottom:86px}


/* サブページ/LP：ヒーローをモバイルで縦積み */
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-side{order:2}
  .hero-copy{order:1}
}

/* 解決実績：文字量が窮屈にならないよう調整 */
.cases-grid{display:grid;gap:16px}
.cases-grid .card{padding:18px 18px 16px}
.cases-grid .card .h3{font-size:18px;margin:0 0 10px}
.cases-grid .card p{font-size:13px;line-height:1.65;margin:0 0 8px}
.cases-grid .card p:last-child{margin-bottom:0}
.cases-grid .card p b{display:inline-block;min-width:3.2em}
@supports (-webkit-line-clamp: 2){
  .cases-grid .card p{
    display:-webkit-box;
    -webkit-box-orient:vertical;
    overflow:hidden;
  }
  .cases-grid .card p.pain{-webkit-line-clamp:2}
  .cases-grid .card p.process{-webkit-line-clamp:2}
  .cases-grid .card p.result{-webkit-line-clamp:2}
}


/* --- v4 adjustments (balance & UX) --- */

/* 2カラムの高さを揃えてしまい空白が出るのを防ぐ */
.split{align-items:start}

/* チェックボックス/ラジオはフォーム共通スタイルの対象外にする */
input[type="checkbox"], input[type="radio"]{
  width:auto;
  padding:0;
  border-radius:4px;
  border:1px solid rgba(229,231,235,.9);
  accent-color: var(--brand);
}

/* 3分診断：チェック欄のサイズを適正化 */
.diag-list input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:2px;
}

/* 追従CTA：3ボタンを同一基準でセンタリング */
.floating-btn{
  height:56px;
  line-height:1;
  white-space:nowrap;
}
.floating-btn .ico{width:18px;height:18px;display:inline-grid;place-items:center;flex:0 0 auto}
.floating-btn span{display:inline-block}

/* 解決実績：case-* クラスへ（.pain 等の衝突回避） */
.case-pain,.case-process,.case-result{font-size:13px;line-height:1.7;margin:0 0 8px;text-align:left}
.case-pain b,.case-process b,.case-result b{font-weight:800}
.cases-grid .card{padding:18px 18px 16px}
.cases-grid .card .h3{font-size:18px;margin:0 0 10px}

/* 事例：タブUI */
.case-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 2px}
.case-tab{
  padding:9px 12px;border-radius:999px;
  border:1px solid var(--line);
  background:#fff;color:var(--muted);
  font-weight:800;font-size:13px;
}
.case-tab[aria-selected="true"]{background:rgba(176,141,87,.12);border-color:rgba(176,141,87,.35);color:var(--ink)}
.case-grid[data-mode="tabs"] .card{display:none}
.case-grid[data-mode="tabs"][data-active="all"] .card{display:block}
.case-grid[data-mode="tabs"] .card[data-cat].is-show{display:block}

/* TOPのチップ（装飾）は上品寄せのため控えめに */
.tags{display:none !important}

/* 診断チェック：表示の崩れを防ぐ */
.diag-list input[type="checkbox"]{appearance:auto;-webkit-appearance:auto;background:transparent}


/* --- Adjustments for requested fixes --- */

/* 代表者写真エリア：上の余白を最小化 */
#representatives.section{padding-top:24px}
.offices{margin-top:10px}
.office{padding-top:16px}
.office .photo img{transform:none !important}

/* 代表写真の見え方（人物像が丁度良くなるよう調整） */
img.rep.daisei{transform:scale(1.08) translateY(0) !important;}
img.rep.hanawa{transform:scale(1.05) translateY(0) !important;}

/* ブログ本文：画像/表/リンク/装飾を見やすく */
.lead img{max-width:100%;height:auto;border-radius:14px;border:1px solid var(--line)}
.lead a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.lead table{width:100%;border-collapse:collapse;margin:14px 0;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.lead th,.lead td{border:1px solid var(--line);padding:10px 10px;font-size:14px;vertical-align:top}
.lead th{background:rgba(0,0,0,.03);font-weight:800}
.lead ul,.lead ol{padding-left:1.2em}



/* v3 cta fix */
.floating-cta{align-items:end}
.floating-btn{align-self:end}
.floating-btn .txt{position:relative;top:1px}