/* ととのえる屋 下層ページ共通 2026 ミニマル・エディトリアル
   くすんだオレンジ1色 / 小さめ文字 / ゴシック / 罫線・余白 */
:root{
  --paper:#E7E4DD;
  --paper-2:#DFDBD2;
  --ink:#1A1814;
  --ink-soft:#3A3730;
  --muted:#8A8579;
  --accent:#C5743C;
  --line:rgba(26,24,20,.14);
  --line-soft:rgba(26,24,20,.08);
  --sans:"Zen Kaku Gothic New",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;line-height:1.8}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--accent);color:var(--paper)}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.lbl.m{color:var(--muted)}

/* ===== トップバー ===== */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:16px 30px;background:rgba(231,228,221,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft)}
.topbar .brand{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500;letter-spacing:.02em}
.topbar .brand img{height:24px;width:auto}
.topbar nav{display:flex;gap:2px;flex-wrap:wrap}
.topbar nav a{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);padding:7px 11px;border-radius:999px;transition:.2s}
.topbar nav a:hover,.topbar nav a[aria-current]{color:var(--accent)}
.topbar .cta{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:8px 16px;border-radius:999px;transition:.25s}
.topbar .cta:hover{background:var(--accent);color:var(--paper)}
@media(max-width:760px){.topbar nav{display:none}}

/* ===== ページヒーロー ===== */
.page-hero{max-width:1280px;margin:0 auto;padding:110px 44px 70px}
.page-hero .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:30px}
.page-hero .eyebrow::before{content:"";width:30px;height:1px;background:currentColor}
.page-hero h1{font-weight:400;font-size:clamp(30px,4.6vw,58px);line-height:1.3;letter-spacing:.005em;max-width:18em}
.page-hero .sub{margin-top:24px;font-size:15px;font-weight:300;color:var(--ink-soft);line-height:2;max-width:40em}
.page-hero .en{font-family:var(--mono);font-size:13px;color:var(--muted);margin-top:14px;letter-spacing:.04em}

/* full-bleed image */
.full-img{max-width:1280px;margin:0 auto 0;overflow:hidden}
.full-img img{width:100%;height:auto;object-fit:cover;filter:saturate(.9);display:block}
.full-img.cover{aspect-ratio:21/9}
.full-img.cover img{height:100%}

/* ===== セクション ===== */
.sec{max-width:1280px;margin:0 auto;padding:110px 44px;border-bottom:1px solid var(--line)}
.sec.narrow{max-width:860px}
.sec-top{display:flex;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:50px;flex-wrap:wrap}
.sec-top h2{font-weight:400;font-size:clamp(22px,3vw,38px);letter-spacing:.005em;line-height:1.3}
.sec-top .note{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}

/* prose / quote */
.prose{max-width:42em;margin:0 auto;font-size:15px;font-weight:300;line-height:2.05;color:var(--ink-soft)}
.prose p{margin-bottom:18px;text-wrap:pretty}
.quote{max-width:24em;margin:0 auto;text-align:center;font-size:clamp(20px,2.6vw,30px);font-weight:300;line-height:1.9;letter-spacing:.01em;color:var(--ink)}
.quote .cite{display:block;margin-top:30px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.center{text-align:center}

/* numbered list（流れ・仕組み） */
.numbered{max-width:720px;margin:0 auto;list-style:none}
.numbered li{display:grid;grid-template-columns:48px 1fr;gap:22px;padding:22px 0;border-bottom:1px solid var(--line);align-items:start}
.numbered li .nn{font-family:var(--mono);font-size:13px;color:var(--accent)}
.numbered li strong{display:block;font-size:16px;font-weight:500;margin-bottom:5px}
.numbered li .d{font-size:13px;font-weight:300;color:var(--muted);line-height:1.8}

/* cases */
.case{max-width:1000px;margin:0 auto 90px}
.case .case-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);text-align:center;margin-bottom:14px}
.case .case-name{font-size:clamp(22px,3vw,32px);font-weight:400;text-align:center;margin-bottom:8px;letter-spacing:.01em}
.case .case-desc{text-align:center;font-size:14px;font-weight:300;color:var(--muted);margin-bottom:34px}
.case .big-img{aspect-ratio:16/9;border-radius:4px;overflow:hidden;margin-bottom:16px}
.case .big-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.case .mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
.case .mini-grid .ph{aspect-ratio:16/10;border-radius:4px;overflow:hidden}
.case .mini-grid img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
@media(max-width:680px){.case .mini-grid{grid-template-columns:1fr}}

/* before / after */
.ba{display:grid;grid-template-columns:1fr 40px 1fr;gap:24px;align-items:center;margin-bottom:40px}
.ba .ph{aspect-ratio:4/3;border-radius:4px;overflow:hidden;margin-bottom:14px}
.ba .ph img{width:100%;height:100%;object-fit:cover;filter:saturate(.88)}
.ba .bl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.ba .bl.after{color:var(--accent)}
.ba .bt{font-size:13px;font-weight:300;line-height:1.9;color:var(--ink-soft)}
.ba .bnum{font-family:var(--mono);color:var(--accent);font-size:1.4em}
.ba .arrow{font-family:var(--mono);color:var(--accent);text-align:center;font-size:20px}
@media(max-width:680px){.ba{grid-template-columns:1fr;gap:14px}.ba .arrow{transform:rotate(90deg)}}

/* testimonial */
.testi{max-width:640px;margin:0 auto;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:4px;padding:26px 28px;display:flex;gap:20px;align-items:flex-start;background:rgba(255,255,255,.3)}
.testi img{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0}
.testi .role{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-bottom:8px}
.testi .q{font-size:16px;font-weight:500;margin-bottom:8px;line-height:1.6}
.testi .dt{font-size:13px;font-weight:300;color:var(--ink-soft);line-height:1.8}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line);max-width:720px;margin:0 auto}
.pricing .p{padding:30px 28px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.pricing .p .nm{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.pricing .p .amt{font-size:clamp(28px,4vw,40px);font-weight:300;color:var(--accent);letter-spacing:-.01em;line-height:1}
.pricing .p .amt small{font-size:14px;color:var(--muted);margin-left:6px;letter-spacing:0}
.pricing .p .pd{font-size:13px;font-weight:300;color:var(--ink-soft);line-height:1.8;margin-top:14px}
@media(max-width:680px){.pricing{grid-template-columns:1fr;border-left:none}.pricing .p{border-right:none}}

/* capacity / accent statement */
.capacity{max-width:560px;margin:0 auto;text-align:center}
.capacity .big{font-size:clamp(18px,2.4vw,26px);font-weight:300;line-height:1.9;margin-bottom:14px}
.capacity .big em{font-family:var(--mono);font-style:normal;color:var(--accent);font-size:1.3em;margin:0 .15em}
.capacity .d{font-size:13px;font-weight:300;color:var(--muted)}

/* profile */
.profile{max-width:680px;margin:0 auto;text-align:center}
.profile .ph{width:140px;height:140px;border-radius:50%;overflow:hidden;margin:0 auto 26px}
.profile .ph img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.profile h3{font-size:20px;font-weight:500;margin-bottom:6px}
.profile .meta{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:26px}
.profile p{font-size:14px;font-weight:300;line-height:2;color:var(--ink-soft);margin-bottom:14px;text-wrap:pretty}

/* product card (totoline) */
.product{background:var(--ink);color:var(--paper)}
.product .sec{border-bottom:none}
.product a.card{display:block;text-decoration:none;color:inherit}
.product .lbl{color:var(--accent)}
.product h2{font-weight:400;font-size:clamp(22px,3vw,34px);line-height:1.4;margin:16px 0 14px;max-width:20em}
.product p{font-size:14px;font-weight:300;line-height:1.95;color:rgba(231,228,221,.8);max-width:42em}
.product .more{margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--accent);color:var(--accent);padding:13px 24px;border-radius:999px;transition:.25s;cursor:pointer}
.btn:hover{background:var(--accent);color:var(--paper)}
.btn.solid{background:var(--accent);color:var(--paper)}
.btn.solid:hover{filter:brightness(1.08)}
.btn.full{display:flex;width:100%;justify-content:center}

/* faq */
.faq{border-top:1px solid var(--line);max-width:860px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:22px 4px;font-size:15px;font-weight:500;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--accent);font-size:18px}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 4px 24px;font-size:14px;font-weight:300;line-height:1.95;color:var(--ink-soft)}

/* contact */
.ct{text-align:center}
.ct .barrier{font-size:14px;font-weight:300;color:var(--ink-soft);line-height:2;margin:0 auto 40px;max-width:30em}
.ct .methods{display:grid;grid-template-columns:1fr 1fr;gap:18px;text-align:left;max-width:760px;margin:0 auto}
.ct .m{border:1px solid var(--line);border-radius:8px;padding:28px 26px;background:rgba(255,255,255,.32)}
.ct .m .lbl{margin-bottom:14px}
.ct .m .v{font-size:17px;font-weight:500;margin-bottom:8px}
.ct .m .nn{font-size:13px;font-weight:300;color:var(--muted);line-height:1.8;margin-bottom:18px}
.ct .m input,.ct .m textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:6px;font:inherit;font-size:14px;font-weight:300;margin-bottom:10px;background:var(--paper);color:var(--ink)}
.ct .m textarea{min-height:80px;resize:vertical}
.ct .m label{font-size:11px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:5px}
.ct-foot{margin-top:40px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);line-height:1.9}
@media(max-width:680px){.ct .methods{grid-template-columns:1fr}}

/* footer */
.site-footer{background:var(--ink);color:var(--paper);padding:64px 44px 30px}
.foot{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px}
.foot .b img{height:50px;width:auto;filter:brightness(0) invert(1);margin-bottom:16px}
.foot .b p{font-size:13px;font-weight:300;line-height:1.9;color:rgba(231,228,221,.6);max-width:320px}
.foot h6{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(231,228,221,.5);margin-bottom:16px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot a{font-size:13px;font-weight:300;color:rgba(231,228,221,.85)}
.foot a:hover{color:var(--accent)}
.foot-bot{max-width:1280px;margin:48px auto 0;padding-top:24px;border-top:1px solid rgba(231,228,221,.14);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:rgba(231,228,221,.5)}
.foot-bot a{color:inherit;text-decoration:underline;text-underline-offset:3px}
@media(max-width:680px){.foot{grid-template-columns:1fr 1fr;gap:28px}}

@media(max-width:760px){
  .page-hero{padding:84px 20px 50px}
  .sec{padding:74px 20px}
  .site-footer{padding-left:20px;padding-right:20px}
  .topbar{padding:13px 18px}
}

/* ===== smooth / reveal（haluta SmoothPass 移植） ===== */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.split-line{display:inline-block;opacity:0;transform:translateY(.5em);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
.in>.split-line,.split-line.in{opacity:1;transform:none}
.img-reveal{overflow:hidden}
.img-reveal img{transform:scale(1.12);filter:blur(12px);opacity:0;transition:transform 1.1s cubic-bezier(.2,.6,.2,1),filter 1.1s cubic-bezier(.2,.6,.2,1),opacity 1.1s ease}
.img-reveal.in img{transform:scale(1);filter:blur(0);opacity:1}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.6,.2,1)}
.fade-up.in,.fade-up.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.split-line,.img-reveal img,.fade-up{opacity:1!important;transform:none!important;filter:none!important}}

/* ===== journal index : リスト + フィルタチップ（home-2026.css .jr 継承） ===== */
.jr{border-top:1px solid var(--line)}
.jr-row{display:grid;grid-template-columns:110px 130px 1fr 30px;gap:24px;align-items:center;padding:20px 4px;border-bottom:1px solid var(--line);transition:padding .3s,background .3s}
.jr-row:hover{padding-left:14px;background:rgba(197,116,60,.05)}
.jr-row .date{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em}
.jr-row .cat{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.jr-row .ti{font-size:15px;font-weight:400;line-height:1.6}
.jr-row .ar{font-family:var(--mono);color:var(--accent);text-align:right}
@media(max-width:720px){.jr-row{grid-template-columns:1fr;gap:5px;padding:16px 0}.jr-row .ar{display:none}}

.jr-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.jr-filter .chip{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);background:transparent;padding:7px 14px;border-radius:999px;cursor:pointer;transition:.2s}
.jr-filter .chip:hover{color:var(--accent);border-color:var(--accent)}
.jr-filter .chip.is-active{color:var(--paper);background:var(--accent);border-color:var(--accent)}
.jr-empty{display:none;padding:48px 4px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}

/* ===== draw-on SVG（集約モチーフ・線が描かれる） ===== */
.draw-svg{display:block}
.draw-svg svg{display:block;width:100%;height:100%;overflow:visible}
.draw-svg line,.draw-svg path,.draw-svg polyline,.draw-svg circle{fill:none;stroke:var(--accent);stroke-width:1;vector-effect:non-scaling-stroke;stroke-linecap:round}
.draw-svg [data-draw]{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset 1.5s cubic-bezier(.2,.6,.2,1)}
.draw-svg.in [data-draw]{stroke-dashoffset:0}
.draw-svg [data-fade]{opacity:0;transition:opacity .8s ease .7s}
.draw-svg.in [data-fade]{opacity:1;fill:var(--accent);stroke:none}
.hero-mark{width:100px;height:56px;margin-bottom:26px}
.divider{max-width:1280px;margin:0 auto;padding:0 44px}
.divider svg{height:12px}
@media(prefers-reduced-motion:reduce){.draw-svg [data-draw]{stroke-dashoffset:0}.draw-svg [data-fade]{opacity:1}}
@media(max-width:760px){.divider{padding:0 20px}}
