/* ---------- hero ---------- */
.hero{padding-block:clamp(80px,12vw,160px) clamp(72px,10vw,120px);text-align:center;position:relative}
.hero-anim{
  position:absolute;inset:0;
  width:100%;height:100%;
  pointer-events:none;
  z-index:0;
  opacity:.92;
  /* Gentle fade toward the text centre so negative space reads as intentional */
  -webkit-mask-image:radial-gradient(ellipse 40% 34% at center,
    transparent 0%,transparent 42%,
    rgba(0,0,0,.55) 62%,
    #000 88%,#000 100%);
  mask-image:radial-gradient(ellipse 40% 34% at center,
    transparent 0%,transparent 42%,
    rgba(0,0,0,.55) 62%,
    #000 88%,#000 100%);
}
.hero-anim path{vector-effect:non-scaling-stroke}
.hero > .container{position:relative;z-index:2}
@media(max-width:640px){.hero-anim{display:none}}
@media(prefers-reduced-motion:reduce){.hero-anim{opacity:.5}}
.hero__copy{
  font-size:clamp(28px,5.2vw,64px);
  font-weight:700;
  letter-spacing:.06em;
  line-height:1.4;
  margin-bottom:32px;
  opacity:0;
  transform:translateY(16px);
  filter:blur(6px);
  transition:opacity 1.4s cubic-bezier(.22,1,.36,1),
             transform 1.4s cubic-bezier(.22,1,.36,1),
             filter 1.4s cubic-bezier(.22,1,.36,1);
  will-change:transform,filter,opacity;
}
.hero__sub{
  color:var(--color-ink);
  font-size:clamp(14px,1.4vw,16px);
  letter-spacing:.16em;
  margin:0 0 52px;
  opacity:0;
  transform:translateY(8px);
  transition:opacity 1s ease .5s,transform 1s ease .5s;
}
.hero__sub em{font-style:normal;font-weight:500;letter-spacing:.26em;margin-left:.4em}
.hero__cta{
  opacity:0;
  transform:translateY(8px);
  transition:opacity .9s ease .8s,transform .9s ease .8s;
}
.hero--revealed .hero__copy{opacity:1;transform:translateY(0);filter:blur(0);animation:heroBreathe 9s ease-in-out 2s infinite}
.hero--revealed .hero__sub,
.hero--revealed .hero__cta{opacity:1;transform:translateY(0)}
@keyframes heroBreathe{
  0%,100%{transform:scale(1);letter-spacing:.06em}
  50%{transform:scale(1.006);letter-spacing:.065em}
}
@media(prefers-reduced-motion:reduce){
  .hero__copy,.hero__sub,.hero__cta{opacity:1;transform:none;filter:none;animation:none;transition:none}
}

/* ---------- pitch section (value proposition + price hook) ---------- */
.pitch{text-align:center}
.pitch__head{margin-bottom:56px}
.pitch__title{
  font-size:clamp(28px,4.4vw,52px);
  font-weight:700;
  letter-spacing:.05em;
  line-height:1.45;
  margin:16px 0 28px;
}
.pitch__lead{
  color:var(--color-sub);
  font-size:clamp(14px,1.55vw,17px);
  line-height:2;
  letter-spacing:.08em;
  margin:0 auto;
  max-width:36em;
}
.pitch__lead em{
  font-style:normal;
  color:var(--color-ink);
  font-weight:500;
  border-bottom:1px solid var(--color-ink);
  padding:0 .15em .05em;
}
.pitch__bridge{
  color:var(--color-sub);
  font-size:clamp(13px,1.35vw,15px);
  line-height:1.95;
  letter-spacing:.1em;
  margin:0 auto 32px;
  max-width:34em;
  padding-top:56px;
  border-top:1px solid var(--color-line);
}
.pitch__price{
  display:inline-flex;
  align-items:center;
  gap:clamp(24px,4vw,64px);
  margin:0 auto 20px;
  padding:28px clamp(24px,4vw,56px);
  border-top:1px solid var(--color-ink);
  border-bottom:1px solid var(--color-ink);
  font-variant-numeric:tabular-nums;
}
.pitch__price-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.pitch__price-label{
  font-size:11px;
  letter-spacing:.3em;
  color:var(--color-mute);
  text-transform:uppercase;
  font-family:var(--font-en);
}
.pitch__price-amount{
  font-size:clamp(30px,4vw,48px);
  font-weight:700;
  letter-spacing:.02em;
  color:var(--color-ink);
  line-height:1;
}
.pitch__price-unit{
  font-size:11px;
  letter-spacing:.18em;
  color:var(--color-sub);
}
.pitch__price-sep{
  width:1px;
  align-self:stretch;
  background:var(--color-line);
}
.pitch__note{
  font-size:11px;
  letter-spacing:.18em;
  color:var(--color-mute);
  margin:0 auto 48px;
}
.pitch__cta{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}
.pitch__link{
  display:inline-block;
  font-size:12px;
  letter-spacing:.18em;
  color:var(--color-sub);
  padding:6px 4px 4px;
  border-bottom:1px solid transparent;
  transition:color .2s,border-color .2s;
}
.pitch__link:hover{color:var(--color-ink);border-bottom-color:var(--color-ink)}
@media(max-width:520px){
  .pitch__price{gap:20px;padding:22px 20px;flex-wrap:nowrap}
  .pitch__price-sep{display:none}
  .pitch__price{flex-direction:column;gap:16px;border-left:0;border-right:0}
}

/* Minimal hero variant — fills viewport so the next section is hidden until scroll */
.hero--minimal{
  min-height:calc(100vh - 64px); /* viewport minus sticky header */
  min-height:calc(100svh - 64px); /* use small-viewport height on supporting browsers */
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding-block:clamp(40px,6vw,80px);
}

.hero__cta{padding:12px 28px;font-size:12px;letter-spacing:.24em;font-family:var(--font-en);font-weight:500;text-transform:uppercase}

/* ---------- story ---------- */
.story-grid{display:grid;gap:40px;grid-template-columns:1fr}
@media(min-width:800px){.story-grid{grid-template-columns:1fr 1fr;gap:72px;align-items:center}}
.story-grid p{color:var(--color-sub)}
.story-grid .h2{margin-bottom:24px}
.story-mark{display:grid;gap:24px;grid-template-columns:1fr 1fr}
.story-mark div{border:1px solid var(--color-line);padding:24px;border-radius:var(--radius)}
.story-mark .label{font-family:var(--font-en);font-size:12px;letter-spacing:.24em;color:var(--color-mute);margin-bottom:8px;display:block;text-transform:uppercase}
.story-mark strong{font-size:28px;letter-spacing:.08em;display:block;margin-bottom:8px}

/* ---------- problems ---------- */
.problem-list{display:grid;gap:16px;grid-template-columns:1fr;max-width:760px;margin:0 auto}
@media(min-width:720px){.problem-list{grid-template-columns:1fr 1fr;gap:20px}}
.problem-list li{border:1px solid var(--color-line);padding:28px;border-radius:var(--radius);display:flex;gap:16px;align-items:flex-start;color:var(--color-sub);font-size:15px;line-height:1.8}
.problem-list li::before{content:"";display:block;flex-shrink:0;width:10px;height:10px;border:1.5px solid var(--color-ink);margin-top:10px;transform:rotate(45deg)}

/* ---------- solutions ---------- */
.solution-list{display:grid;gap:28px;grid-template-columns:1fr}
@media(min-width:720px){.solution-list{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.solution-list{grid-template-columns:repeat(4,1fr)}}
.solution-list li{padding:32px 24px;border:1px solid var(--color-line);border-radius:var(--radius)}
.solution-list .icon{width:40px;height:40px;color:var(--color-ink);margin-bottom:20px}
.solution-list h3{font-size:17px;font-weight:500;margin-bottom:10px}
.solution-list p{font-size:14px;color:var(--color-sub);line-height:1.75}

/* ---------- quality standard (Lighthouse target scores on service page) ---------- */
.quality{
  display:flex;
  flex-direction:column;
  gap:20px;
  max-width:560px;
  margin:0 auto;
  list-style:none;
  padding:0;
}
.quality__row{
  display:grid;
  grid-template-columns:130px 1fr 60px;
  gap:20px;
  align-items:center;
}
@media(max-width:520px){
  .quality__row{grid-template-columns:100px 1fr 50px;gap:14px}
}
.quality__label{
  font-family:var(--font-en);
  font-size:12px;
  letter-spacing:.14em;
  color:var(--color-sub);
  text-transform:uppercase;
}
.quality__bar{
  display:block;
  height:6px;
  background:var(--color-line);
  border-radius:1px;
  overflow:hidden;
  position:relative;
}
.quality__fill{
  display:block;
  height:100%;
  width:calc(var(--v) * 1%);
  background:var(--color-ink);
  transition:width 1.4s cubic-bezier(.22,1,.36,1);
}
.quality__score{
  font-family:var(--font-en);
  font-size:18px;
  font-weight:700;
  color:var(--color-ink);
  font-variant-numeric:tabular-nums;
  text-align:right;
  line-height:1;
}
.quality__score small{
  font-size:.7em;
  font-weight:500;
  color:var(--color-sub);
  margin-left:1px;
}
.quality__note{
  margin-top:36px;
  padding-top:24px;
  border-top:1px solid var(--color-line);
  font-size:12px;
  line-height:1.8;
  letter-spacing:.05em;
  color:var(--color-mute);
  text-align:center;
  max-width:540px;
  margin-left:auto;
  margin-right:auto;
}

/* ---------- advisory (IT/AI consulting on about page) ---------- */
.advisory{
  max-width:880px;
  margin:0 auto;
  padding:clamp(32px,4.5vw,64px);
  border:1px solid var(--color-ink);
  border-radius:var(--radius);
  background:#fff;
}
.advisory__capacity{
  text-align:center;
  margin-bottom:40px;
  padding-bottom:40px;
  border-bottom:1px solid var(--color-line);
}
.advisory__capacity-head{
  display:block;
  font-family:var(--font-en);
  font-size:11px;
  letter-spacing:.36em;
  color:var(--color-mute);
  text-transform:uppercase;
  margin-bottom:24px;
}
.advisory__slots{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:clamp(6px,1vw,12px);
  margin:0 0 28px;
  padding:0;
  list-style:none;
}
.advisory__slots li{
  width:clamp(38px,5.2vw,56px);
  height:clamp(38px,5.2vw,56px);
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--color-ink);
  font-family:var(--font-en);
  font-size:clamp(10px,1vw,12px);
  font-weight:500;
  letter-spacing:.1em;
  color:var(--color-sub);
  background:#fff;
  transition:background .25s ease,color .25s ease,transform .25s ease;
}
.advisory__slots li:hover{
  background:var(--color-ink);
  color:#fff;
  transform:translateY(-2px);
}
.advisory__capacity-note{
  font-size:13.5px;
  line-height:2;
  letter-spacing:.08em;
  color:var(--color-sub);
  max-width:40em;
  margin:0 auto;
}
.advisory__capacity-note strong{
  color:var(--color-ink);
  font-weight:700;
  letter-spacing:.1em;
}
.advisory__capacity-note em{
  font-style:normal;
  color:var(--color-ink);
  font-weight:500;
  border-bottom:1px solid var(--color-ink);
  padding:0 .15em .05em;
}
.advisory__core{
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
  padding:40px 0;
  margin-bottom:36px;
  border-top:1px solid var(--color-line);
  border-bottom:1px solid var(--color-line);
  position:relative;
}
@media(min-width:620px){
  .advisory__core{
    grid-template-columns:1fr 1fr;
    gap:clamp(24px,4vw,48px);
  }
  .advisory__core::before{
    content:"";
    position:absolute;
    left:50%;
    top:40px;
    bottom:40px;
    width:1px;
    background:var(--color-line);
  }
}
.advisory__figure{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-align:center;
}
.advisory__figure small{
  font-size:11px;
  letter-spacing:.24em;
  color:var(--color-mute);
  text-transform:uppercase;
  font-family:var(--font-en);
}
.advisory__figure strong{
  font-size:clamp(28px,3.4vw,40px);
  font-weight:700;
  letter-spacing:.03em;
  color:var(--color-ink);
  font-variant-numeric:tabular-nums;
  line-height:1.1;
}
.advisory__desc{
  color:var(--color-sub);
  font-size:15px;
  line-height:2;
  letter-spacing:.05em;
  max-width:42em;
  margin:0 auto 40px;
  text-align:center;
}
.advisory__scope h4{
  font-family:var(--font-en);
  font-size:11px;
  font-weight:500;
  letter-spacing:.3em;
  color:var(--color-mute);
  text-transform:uppercase;
  text-align:center;
  margin-bottom:24px;
}
.advisory__scope ul{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
@media(min-width:640px){
  .advisory__scope ul{grid-template-columns:1fr 1fr}
}
.advisory__scope li{
  padding:12px 8px 12px 30px;
  font-size:14px;
  line-height:1.7;
  color:var(--color-sub);
  letter-spacing:.04em;
  position:relative;
  border-bottom:1px solid var(--color-line);
}
.advisory__scope li::before{
  content:"";
  position:absolute;
  left:4px;
  top:18px;
  width:12px;
  height:7px;
  border-left:1.5px solid var(--color-ink);
  border-bottom:1.5px solid var(--color-ink);
  transform:rotate(-45deg);
}
.advisory__cta{
  text-align:center;
  margin-top:44px;
  padding-top:36px;
  border-top:1px solid var(--color-line);
}
.advisory__cta-note{
  margin-top:14px;
  font-size:12px;
  color:var(--color-mute);
  letter-spacing:.08em;
}

/* ---------- partner (role redefinition: you focus / we take care) ---------- */
.partner{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
  max-width:980px;
  margin:0 auto;
  align-items:center;
}
@media(min-width:820px){
  .partner{
    grid-template-columns:1fr 1px 1.3fr;
    gap:clamp(40px,5vw,72px);
  }
}
.partner__label{
  display:block;
  font-family:var(--font-en);
  font-size:11px;
  letter-spacing:.3em;
  color:var(--color-mute);
  text-transform:uppercase;
  margin-bottom:24px;
}
.partner__you{text-align:center}
.partner__head{
  font-size:clamp(34px,4.4vw,52px);
  font-weight:700;
  letter-spacing:.06em;
  line-height:1.35;
  color:var(--color-ink);
  margin-bottom:20px;
}
.partner__note{
  color:var(--color-sub);
  font-size:14px;
  letter-spacing:.12em;
}
.partner__divider{
  background:var(--color-line);
  align-self:stretch;
  width:1px;
  justify-self:center;
}
@media(max-width:819px){
  .partner__divider{height:1px;width:auto;min-height:1px}
}
.partner__list{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
}
@media(min-width:600px){
  .partner__list{grid-template-columns:1fr 1fr}
}
.partner__list li{
  padding:14px 4px 14px 26px;
  border-bottom:1px solid var(--color-line);
  font-size:13px;
  line-height:1.65;
  letter-spacing:.02em;
  color:var(--color-sub);
  position:relative;
}
.partner__list li::before{
  content:"";
  position:absolute;
  left:3px;
  top:17px;
  width:11px;
  height:6px;
  border-left:1.5px solid var(--color-ink);
  border-bottom:1.5px solid var(--color-ink);
  transform:rotate(-45deg);
}
.partner__closing{
  text-align:center;
  margin:72px auto 0;
  padding-top:48px;
  border-top:1px solid var(--color-line);
  font-size:clamp(16px,1.7vw,20px);
  letter-spacing:.12em;
  line-height:1.9;
  color:var(--color-sub);
  max-width:40em;
}
.partner__closing em{
  font-style:normal;
  color:var(--color-ink);
  font-weight:500;
  border-bottom:1px solid var(--color-ink);
  padding:0 .15em .05em;
}

/* ---------- craft (no-template differentiation) ---------- */
.craft-wrap{
  max-width:920px;
  margin:0 auto;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.craft-compare{
  width:100%;
  min-width:640px;
  border-collapse:collapse;
  font-size:13px;
  background:#fff;
}
.craft-compare th,
.craft-compare td{
  padding:14px 12px;
  border-bottom:1px solid var(--color-line);
  text-align:center;
  letter-spacing:.04em;
  vertical-align:middle;
  line-height:1.6;
}
.craft-compare thead th{
  font-size:11px;
  font-weight:500;
  letter-spacing:.14em;
  color:var(--color-sub);
  padding:18px 12px;
  border-bottom:1px solid var(--color-ink);
  background:#fff;
}
.craft-compare thead th.is-koho{
  color:var(--color-ink);
  font-weight:700;
  font-size:13px;
  letter-spacing:.18em;
  font-family:var(--font-en);
  background:var(--color-ink);
  color:#fff;
}
.craft-compare tbody th{
  text-align:left;
  font-size:12px;
  font-weight:500;
  color:var(--color-ink);
  letter-spacing:.08em;
  width:22%;
  background:#FAFAFA;
}
.craft-compare td{
  color:var(--color-sub);
  width:26%;
}
.craft-compare td.is-koho{
  background:#F3F3F3;
  color:var(--color-ink);
  font-weight:500;
  position:relative;
}
.craft-compare tbody tr:last-child td,
.craft-compare tbody tr:last-child th{border-bottom:0}
.craft-note{
  text-align:center;
  max-width:36em;
  margin:48px auto 0;
  padding-top:36px;
  border-top:1px solid var(--color-line);
  font-size:clamp(14px,1.55vw,16px);
  line-height:2;
  letter-spacing:.08em;
  color:var(--color-sub);
}
.craft-note em{
  font-style:normal;
  color:var(--color-ink);
  font-weight:500;
  border-bottom:1px solid var(--color-ink);
  padding:0 .15em .05em;
}
@media(max-width:640px){
  .craft-compare{font-size:12px}
  .craft-compare th,
  .craft-compare td{padding:10px 8px}
  .craft-compare tbody th{font-size:11px;width:22%}
}

/* ---------- price philosophy (3 principles) ---------- */
.section-lead{
  color:var(--color-sub);
  font-size:clamp(14px,1.5vw,16px);
  line-height:2;
  letter-spacing:.08em;
  margin:24px auto 0;
  max-width:38em;
}
.section-lead em{
  font-style:normal;
  color:var(--color-ink);
  font-weight:500;
  border-bottom:1px solid var(--color-ink);
  padding:0 .15em .05em;
}
.principles{
  display:grid;
  grid-template-columns:1fr;
  gap:40px;
  margin:64px auto 72px;
  max-width:1040px;
  counter-reset:principle;
}
@media(min-width:820px){
  .principles{grid-template-columns:repeat(3,1fr);gap:48px}
}
.principle{
  padding-top:24px;
  border-top:1px solid var(--color-ink);
  list-style:none;
}
.principle__num{
  display:inline-block;
  font-family:var(--font-en);
  font-size:11px;
  font-weight:500;
  letter-spacing:.3em;
  color:var(--color-mute);
  margin-bottom:20px;
}
.principle__head{
  font-size:clamp(17px,1.9vw,21px);
  font-weight:700;
  letter-spacing:.04em;
  line-height:1.5;
  margin-bottom:16px;
  color:var(--color-ink);
}
.principle__body{
  font-size:14px;
  line-height:1.95;
  color:var(--color-sub);
  letter-spacing:.04em;
}

/* ---------- price ---------- */
.price-box{max-width:760px;margin:0 auto;border:1px solid var(--color-ink);border-radius:var(--radius);padding:clamp(32px,4vw,56px);background:#fff}
.price-box__head{text-align:center;padding-bottom:32px;border-bottom:1px solid var(--color-line);margin-bottom:32px}
.price-box__label{font-family:var(--font-en);font-size:12px;letter-spacing:.24em;color:var(--color-mute);display:block;margin-bottom:8px;text-transform:uppercase}
.price-box__name{font-size:24px;font-weight:700;letter-spacing:.08em}
.price-row{display:grid;gap:12px;grid-template-columns:1fr;text-align:center;margin-bottom:32px}
@media(min-width:640px){.price-row{grid-template-columns:1fr 1fr;gap:32px}}
.price-row > div{padding:20px 0}
@media(min-width:640px){.price-row > div + div{border-left:1px solid var(--color-line)}}
.price-row .label{display:block;font-size:13px;color:var(--color-mute);margin-bottom:10px;letter-spacing:.1em}
.price-row .amount{font-family:var(--font-en);font-size:clamp(32px,4.5vw,48px);font-weight:700}
.price-row .amount small{font-family:var(--font-jp);font-size:15px;font-weight:400;color:var(--color-sub);margin-left:4px}

/* ---------- steps ---------- */
.steps{display:grid;gap:20px;grid-template-columns:1fr;counter-reset:step}
@media(min-width:760px){.steps{grid-template-columns:repeat(5,1fr);gap:16px}}
.steps li{padding:28px 20px;border:1px solid var(--color-line);border-radius:var(--radius);position:relative}
.steps li::before{counter-increment:step;content:"0" counter(step);display:block;font-family:var(--font-en);font-size:13px;letter-spacing:.24em;color:var(--color-mute);margin-bottom:14px}
.steps h3{font-size:15px;font-weight:500;margin-bottom:8px}
.steps p{font-size:13px;color:var(--color-sub);line-height:1.75}

/* ---------- profile ---------- */
.profile{display:grid;gap:clamp(32px,5vw,64px);grid-template-columns:1fr;align-items:center;max-width:960px;margin:0 auto}
@media(min-width:720px){.profile{grid-template-columns:minmax(0,240px) 1fr}}
.profile__photo{aspect-ratio:3/4;background:#F5F5F5;border:1px solid var(--color-line);display:flex;align-items:center;justify-content:center;border-radius:var(--radius);overflow:hidden}
.profile__photo svg{width:55%;height:auto;color:var(--color-mute)}
.profile__photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.profile__photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.profile__name{font-size:22px;font-weight:700;margin-bottom:4px}
.profile__role{font-size:13px;color:var(--color-mute);letter-spacing:.1em;margin-bottom:20px}
.profile__msg{color:var(--color-sub);font-size:15px;line-height:1.9;margin-bottom:24px;max-width:52ch}

/* ---------- faq ---------- */
.faq-list{max-width:800px;margin:0 auto;border-top:1px solid var(--color-line)}
.faq-list details{border-bottom:1px solid var(--color-line)}
.faq-list summary{padding:24px 48px 24px 0;font-size:16px;font-weight:500;cursor:pointer;position:relative;list-style:none;line-height:1.6}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::before{content:"Q";display:inline-block;font-family:var(--font-en);font-size:13px;letter-spacing:.1em;color:var(--color-mute);margin-right:16px;vertical-align:baseline}
.faq-list summary::after{content:"";position:absolute;right:4px;top:50%;width:14px;height:14px;background-image:linear-gradient(var(--color-ink),var(--color-ink)),linear-gradient(var(--color-ink),var(--color-ink));background-size:14px 1.5px,1.5px 14px;background-position:center;background-repeat:no-repeat;transition:transform .2s;transform:translateY(-50%)}
.faq-list details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-list details[open] summary{color:var(--color-ink)}
.faq-list .answer{padding:0 48px 24px 32px;color:var(--color-sub);font-size:15px;line-height:1.9}
.faq-list .answer::before{content:"A";display:inline-block;font-family:var(--font-en);font-size:13px;letter-spacing:.1em;color:var(--color-mute);margin-right:16px;vertical-align:baseline;margin-left:-32px}
.faq-category{margin-top:56px;margin-bottom:12px;font-size:13px;letter-spacing:.2em;color:var(--color-mute);text-transform:uppercase;font-family:var(--font-en);max-width:800px;margin-inline:auto;padding-left:16px}

/* ---------- cta band ---------- */
.cta{background:var(--color-ink);color:#fff;text-align:center;padding-block:clamp(72px,10vw,120px)}
.cta .h2{color:#fff;margin-bottom:20px}
.cta p{color:rgba(255,255,255,.72);max-width:52ch;margin:0 auto 40px;font-size:15px}
.cta .btn{background:#fff;color:var(--color-ink);border-color:#fff}
.cta .btn:hover{background:#F5F5F5}

/* ---------- page header (sub pages) ---------- */
.page-head{padding-block:clamp(64px,9vw,120px) clamp(40px,5vw,64px);text-align:center;border-bottom:1px solid var(--color-line)}
.page-head h1{font-size:clamp(32px,5vw,52px);font-weight:700;letter-spacing:.04em;margin-bottom:16px}
.page-head p{color:var(--color-sub);font-size:15px}

/* ---------- service page ---------- */
.included-list{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:640px){.included-list{grid-template-columns:1fr 1fr}}
.included-list li{padding:16px 20px;border:1px solid var(--color-line);border-radius:var(--radius);display:flex;gap:12px;align-items:flex-start;font-size:14px;line-height:1.7;color:var(--color-sub)}
.included-list li::before{content:"";width:14px;height:14px;border:1.5px solid var(--color-ink);border-top:0;border-right:0;transform:rotate(-45deg);flex-shrink:0;margin-top:4px}

/* ---------- contact page ---------- */
.form-wrap{max-width:720px;margin:0 auto;border:1px solid var(--color-line);border-radius:var(--radius);overflow:hidden}
.form-wrap iframe{display:block;width:100%;min-height:900px;border:0}
.form-placeholder{padding:48px 32px;text-align:center;color:var(--color-mute);background:#FAFAFA}

/* Contact form mockup (preview before Google Form embed) */
.contact-form{
  max-width:640px;
  margin:0 auto;
  padding:48px clamp(24px,4vw,56px);
  border:1px solid var(--color-line);
  border-radius:var(--radius);
  background:#fff;
}
.form-field{margin-bottom:28px}
.form-field label{
  display:block;
  font-size:13px;
  font-weight:500;
  letter-spacing:.12em;
  color:var(--color-ink);
  margin-bottom:10px;
}
.form-required{
  display:inline-block;
  font-size:10px;
  color:var(--color-ink);
  margin-left:8px;
  padding:2px 8px;
  border:1px solid var(--color-ink);
  letter-spacing:.18em;
  vertical-align:middle;
}
.form-field input[type="text"],
.form-field input[type="email"],
.form-field select,
.form-field textarea{
  width:100%;
  padding:14px 16px;
  border:1px solid var(--color-line);
  border-radius:var(--radius);
  font-family:var(--font-jp);
  font-size:15px;
  line-height:1.6;
  background:#fff;
  color:var(--color-ink);
  transition:border-color .2s;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--color-ink);
}
.form-field textarea{resize:vertical;min-height:88px;font-family:inherit}
.form-field select{
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%231A1A1A' stroke-width='1.2'><path d='M1,1 L6,6 L11,1'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:12px auto;
  padding-right:40px;
}
.form-field--consent{margin-top:32px;padding-top:24px;border-top:1px solid var(--color-line)}
.form-field--consent label{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--color-sub);
  letter-spacing:.06em;
  cursor:pointer;
  font-weight:400;
  margin:0;
}
.form-field--consent input[type="checkbox"]{
  width:16px;
  height:16px;
  accent-color:var(--color-ink);
  cursor:pointer;
  flex-shrink:0;
}
.contact-form__submit{
  display:block;
  width:100%;
  padding:18px 32px;
  background:var(--color-ink);
  color:#fff;
  border:1px solid var(--color-ink);
  border-radius:var(--radius);
  font-family:var(--font-jp);
  font-size:14px;
  font-weight:500;
  letter-spacing:.2em;
  cursor:pointer;
  transition:background .15s,transform .15s;
  margin-top:8px;
}
.contact-form__submit:hover{background:#000;transform:translateY(-1px)}
.contact-form__submit span{margin-left:8px;transition:transform .15s}
.contact-form__submit:hover span{transform:translateX(3px)}
.contact-form__note{
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid var(--color-line);
  font-size:12px;
  line-height:1.9;
  letter-spacing:.05em;
  color:var(--color-mute);
}
.contact-form__note a{text-decoration:underline;color:var(--color-sub)}

/* ---------- about page ---------- */
.profile-full{max-width:720px;margin:0 auto}
.profile-full__photo{aspect-ratio:3/4;max-width:320px;margin:0 auto 40px;background:#F5F5F5;border:1px solid var(--color-line);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;overflow:hidden}
.profile-full__photo svg{width:55%;color:var(--color-mute)}
.profile-full__photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.profile-full h1{text-align:center;font-size:32px;font-weight:700;margin-bottom:8px;letter-spacing:.04em}
.profile-full .role{text-align:center;color:var(--color-mute);font-size:13px;letter-spacing:.1em;margin-bottom:48px}
.profile-full .bio{color:var(--color-sub);line-height:2;font-size:15px;margin-bottom:40px}
.profile-full .bio p + p{margin-top:1.2em}
.career{display:grid;gap:16px;grid-template-columns:1fr;margin-top:16px}
@media(min-width:640px){.career{grid-template-columns:140px 1fr}}
.career dt{font-size:13px;color:var(--color-mute);letter-spacing:.08em;font-family:var(--font-en)}
.career dd{color:var(--color-sub);font-size:15px;margin:0}
.career__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:20px}
.career__list li{position:relative;padding-left:18px}
.career__list li::before{
  content:"-";
  position:absolute;
  left:0;
  top:0;
  color:var(--color-ink);
  font-size:16px;
  line-height:1.5;
}
.career__org{
  display:block;
  color:var(--color-ink);
  font-weight:500;
  font-size:15px;
  letter-spacing:.04em;
  margin-bottom:4px;
}
.career__role{
  display:block;
  color:var(--color-sub);
  font-size:14px;
  line-height:1.8;
  letter-spacing:.03em;
}

/* ---------- works (portfolio template) ---------- */
.works-empty{
  max-width:520px;
  margin:0 auto;
  text-align:center;
  padding:72px 24px;
  border:1px solid var(--color-line);
  border-radius:var(--radius);
}
.works-empty__body{
  color:var(--color-sub);
  font-size:15px;
  line-height:2;
  letter-spacing:.06em;
  margin-bottom:32px;
}
.works-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
  list-style:none;
  padding:0;
  max-width:var(--max);
  margin:0 auto;
}
@media(min-width:720px){.works-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.works-grid{grid-template-columns:repeat(3,1fr)}}
.work{list-style:none}
.work__link{
  display:block;
  border:1px solid var(--color-line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color .2s,transform .2s;
}
.work__link:hover{border-color:var(--color-ink);transform:translateY(-2px)}
.work__thumb{aspect-ratio:4/3;background:#F5F5F5;overflow:hidden}
.work__thumb img{width:100%;height:100%;object-fit:cover}
.work__meta{padding:20px 22px 24px}
.work__category{
  display:inline-block;
  font-family:var(--font-en);
  font-size:11px;
  letter-spacing:.2em;
  color:var(--color-mute);
  text-transform:uppercase;
  margin-bottom:8px;
}
.work__title{
  font-size:18px;
  font-weight:700;
  letter-spacing:.04em;
  margin-bottom:10px;
  color:var(--color-ink);
}
.work__summary{
  font-size:14px;
  line-height:1.8;
  color:var(--color-sub);
  margin-bottom:12px;
}
.work__tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.work__tags span{
  font-size:11px;
  letter-spacing:.1em;
  color:var(--color-sub);
  padding:3px 10px;
  border:1px solid var(--color-line);
  border-radius:999px;
}

/* ---------- 404 ---------- */
.not-found{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding-block:120px 80px}
.not-found h1{font-family:var(--font-en);font-size:clamp(64px,14vw,120px);font-weight:700;letter-spacing:.04em;margin-bottom:24px}
.not-found p{color:var(--color-sub);margin-bottom:40px;max-width:44ch}
